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INTRDDQCTION 

ADVANCED DIGITAL CORPORATION is proud to introduce the SUPER QUAD. 
The SUPER QUAD is a Z80 based single board computer designed to be 
a bus master in an S100 bus system. The SUPER QUAD SBC has all the 
hardware needed to run a single user CP/M system or 2 user MP/M 
system with up to 4 external floppy disk drives and an external 
Centronics parallel interface printer all on one board. 
The board also runs with TURBO-DOS tm. 
The SUPER QUAD SBC contains: 

1) Z-80A cpu (4 MHZ) 

2) Floppy disk controller (up to 4 drives 8" or 5V*) 

3) 64K of dynamic memory (16K bank selectible) 

4) 2K or 4K of shadow eprom (2716 or 2732) 

5) 2 serial ports (Z80A SIO opt. syncronous) 

6) 2 12 bit parallel ports, (Z80A PIO) 
one of which can be used 

for S100 vectored interrupts 

7) Real time interrupt clock (Z80A CTC) 

8) S100 extended address A16-A23 

ONE YEAR WARRANTY. 



*Note: Items 5 and 6 require external adaptation for RS-232 and 
Centronics. The adapter boards are 2 x 2" and are called 
PS NET. They hoop up to the back of the main frame with 
a DB-25 connector. 
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1.1 The Floppy Disk Controller 

The floppy disk controller can access up to four 8 inch or 5.25 
inch floppy disk drives. It can read and write IBM 3740 single 
density format and double density 128,256,512,1024 sector size 
formats. Data transfer is done by programmed I/O with wait and 
interrupt syncronization. 

Note : The controller cannot access both 8 inch and 5.25 inch drives 
simultaniously,The controller is switched from 8 inch to 5.25 inch 
drives by hardware jumper options. 

1.2 The 64 k Dynamic ram 



The 64 k ram array can be switched on and off in 16 k increments 
(0-16K,16K-32K,32K-48K,48K-64K) under software control. This allows the 
CPU to access bank switchable external memory on the S100 bus. 
The memory has an access time of 200ns. Refresh is done during 
Z80 Ml cycles and during wait and reset states. The memory can 
be accessed by an external DMA device on the S100 bus. 
Note : Any external DMA device that is using continous mode DMA 
cycles must transfer data at an average rate of 15 us per byte or 
Easter when holding the DMA request line for more than 1.5 ms This is 
not a problem because most designers are smart enough to use 
byte-at-a-time or burst transfer modes when dealing with slow DMA 
transfer rates. The ram row address is the low order address there- 
for the entire ram array is refreshed by the DMA device every 128 
contiguous memory cycles. 



1.3 System Monitor Eprom 

The system monitor eprom is switched on during reset. It can be 

disabled and enabled under software control. It resides when 

enabled at F000h to FFFFh. It has commands that allow the user 

to load the CP/M , MP/M or other boot loaders from floppy disk. 

In addition it can be used to load r examine goto and test 

memory. When the prom is disabled, it does not use any system address 

space. 

1.4 Serial ports 

A Z80A DART is used for the two serial ports , but 

a Z80A SIO/0 chip can be used in it's place. This allows 

asyncronous and synchronous serial data communications plus a variety 

of interrupt modes. Modem control signals are available at each 

serial connector. There are two switch select ible baud rate 

generators for baud rates of 50 to 19.2 k baud. 

Note : The serial ports are TTL and must be connected to external 

interface boards for RS232 communications. 

(PS NET/I) 

1 .5 Parallel ports 



A Z80A PIO is used as the parallel port. The "A" channel of this chip 
is connected to the parallel port connector. This port has 8 bi-dir- 
ectional data lines and two hand shake lines. The "B" port can be split 
between the parallel port connector and the S100 bus vectored interrupt 
lines by jumper options. This allows the port to be used as an 
additional parallel port or interrupt controller or both. 
In the output mode the parallel ports can drive one TTL load . 



1.6 Real Time Interrupt clock 

A Z80A CTC is used for providing a real time system clock for MP/M. 
Three channels of the CTC are available to the user for strapping via 
a jumper header for synchronous baud rates or long clock times. 

1.7 S100 Bus Interface 



The S100 bus interface provides the signals necessary for an 8 bit 
bus master as described by the IEEE 696 bus specification. 
Vectored interrupt lines VI0 - VI7 are supported via jumper options 
and A16 - A23 are also supported vis an I/O port. 
The PAMNTON line is also implemented for the dynamic ram array. 



2.0 EPROM and Monitor operation 

The onboard EPROM occupies address F000H-FFFFH. The EPROM 
is switched on automatically during reset or power on, the 
EPROM contains SIO and FDC initialization code along with a 
simple debugger and floppy disk cold start loader. After 
the operating system is loaded the EPROM can be turned off 
so that the ram at address F000H-FFFFH can be accessed. The 
EPROM can be turned on and off at any time so that hardware 
dependent I/O routines can be called. 

2.1 Eprom Enable / Disable 

Switching EPROM on : 

F033 3E4F MVI A r 01001111B ;RESET POWER ON JUMP 

; AND ENABLE MEMORY, EPROM ON 
F035 D316 OUT 16H ;WRITE TO CONTROL PORT 

Switching EPROM off : 

F033 3E4F MVI A,01101111B ;RESET POWER ON JUMP 

; AND ENABLE MEMORY, EPROM OFF 
F035 D316 OUT 16H ;WRITE TO CONTROL PORT 

Jumper R configures the board to accept a 2716 or 2732 EPROM. 
Note : The EPROM is always addressed at F800H and can not 
be moved. Since the 2716 EPROM is 2K long it appears 
twice , F800H-FC00H and FBFFH-FEFFH. 

2.2 Monitor Signon 

The EPROM contains a simple debugger. 
The monitor signs on with : 

> ADVANCED DIGITAL CORP. 

Monitor Version 1.1 

Mar - 1982 

press "H" for help 
> 

2.3 Monitor Commands 



The monitor commands are : 

Control B - Load disk boot loader 5.25" 

Control C = Load disk boot loader 8 " 

D SSSS QQQQ - Dump memory in hex from SSSS to QQQQ 

F SSSS QQQQ BB * Fill memory from SSSS to QQQQ with BB 

G AAAA = Go to address AAAA 

L AAAA = Load memory starting at AAAA 

M SSSS QQQQ DD = Move from S to Q to ADDR DD 

P SSSS QQQQ - Print in ascii from SSSS to QQQQ 

T - Test Memory 

ESC will terminate any command 



The cold boot loader will select and home drive 0. 

Track sector 1 will be read into memory at location 0. 

Single density is assumed for track 0. 

If an error occures an error code will be printed. 

The error code must be translated using the table 

in appendex F page F-4 fig 2. 

e.g. FDC COLD BOOT ERROR 80= DISK NOT DETECTED 

FDC COLD BOOT ERROR 10= WRONG FORMAT OR NO DATA ON DISK OR BAD PHASE LO< 

LOOP. 

2.4 Cold Boot Program 

; READ TRACK SECTOR 1 INTO MEMORY 



;set double for 5 inch 

; RESET FDC 

: ISSUE COMMAND 







BOOT 5: 


MVI 
OUT 


A,08H 
WAIT 






BOOT: 






F4B5 


3E0D 




MVI 


A r 0DH 


F4B7 


D30C 




OUT 


FDC 


F4B9 


00 


FDCW1 : 


NOP 




F4BA 


DB0C 




IN 


FDC 


F4BC 


0F 




RRC 




F4BD 


DABAF4 




JC 


FDCW1 


F4C0 


00 




NOP 





; CHECK BUSY 



; KILL TIME 



F4C1 00 
F4C2 00 



NOP 
NOP 



F4C3 



NOP 



F4C4 


3E03 


MVI 


A, 3 


; GET A RESTORE 


F4C6 


D30C 


OUT 


FDC 


; ISSUE COMMAND 


F4C8 


00 


NOP 






F4C9 


DB14 


IN 


WAIT 


; WAIT FOR 


F4CB 


00 


NOP 
TK0: 




; INTRQ 


F4CC 


DB0C 


IN 


FDC 




F4CE 


E604 


ANI 


4 


; CHECK TRACK 


F4D0 


CACCF4 


JZ 


TK0 




F4D3 


AF 


XRA 


A 




F4D4 


6F 


MOV 


L,A 


• t POINT AT LOC 


F4D5 


67 


MOV 


H,A 




F4D6 


3C 


INR 


A 




F4D7 


D30E 


OUT 


FDCSEC 


• SET SECTOR 


F4D9 


3E8C 


MVI 


A,08CH 


; GET READ COMMAND 


F4DB 


D30C 


OUT 


FDC 


• ISSUE COMMAND 


F4DD 


00 


NOP 
FDCRD: 






F4DE 


DB14 


IN 


WAIT 


; WAIT FOR INTRQ 


F4E0 


B7 


ORA 


A ; 


• OR DRQ 


F4E1 


F2EBF4 


JP 


BOOTDN 


j EXIT IF INTRQ 


F4E4 


DB0F 


IN 


FDCDATA i 


' GET DATA 


ME6 


77 


MOV 


M,A 


• f STORE 


F4E7 


23 


INX 


H ; 


POINT NEXT 


F4E8 


C3DEF4 


JMP 
BOOTDN : 


FDCRD 




F4EB 


DB0C 


IN 


FDC 


; CHECK STATUS 


F4ED 


B7 


ORA 


A 


= NO ERROR 


F4EE 


CA0000 


JZ 





; OK, GO 


F4F1 


F5 


PUSH 


PSW j 


SAVE ERROR 


F4F2 


210FF6 


LXI 


H,BTERR 


; PRINT 


F4F5 


CDE6F0 


CALL 


MSG ; 


DISK ERROR 


F4F8 


Fl 


POP 


PSW 


j GET ERROR 


F4F9 


CD21F1 


CALL 


THXB j 


PRINT IT 



3.0 



INPUT / OUTPUT PORT ASS1GMENTS 



Address 




Function 






00 


Read/Wr ite 


SIO Channel A 


Data port 




01 


Read/Wr ite 


SIO Channel A 


Status/Control 


Port 


02 


Read/Write 


SIO Channel B 


Data port 




03 


Read/Write 


SIO Channel B 


Status/Control 


Por t 


04 


Read/Write 


PIO Channel A 


Data port 




05 


Read/Write 


PIO Channel B 


Data port 




06 


Write 


PIO Channel A 


Control port 




07 


Write 


PIO Channel B 


Control Port 




08 


Read/Wr ite 


CTC Channel 


Control Port 




09 


Read/Write 


CTC Channel 1 


Control Portol 




0A 


Read/Write 


CTC Channel 2 


Control Port 




0B 


Read/Write 


CTC Channel 3 


Control Port 




0C 


Read/Write 


FDC Command/States Port 




0D 


Read/Write 


FDC Track Register 




0E 


Read/Write 


FDC Sector Register 




0F 


Read/Wr ite 


FDC Data Port 






10 




Unused 






11 




Unused 






12 




Unused 






13 




Unused 






14 


Read/Write 


FDC Syncronization/Dr ive/Dens 


ii ty 


15 


Wr i te 


S100 Buss Extended Address A16-A2- 


16 


Wr ite 


On-Board Memoi 


:y Control Port 




17 




Unused 






18 




Unused 






19 




Unused 






1A 




Unused 






IB 




Unused 






1C 




Unused 






ID 




Unused 






IE 




Unused 






IF 




Unused 







All addresses are listed in Hexidecimal. 

The unused input / output ports are internally decoded and 

should not be used by external S100 I/O boards. 
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4.0 INPUT / OUTPUT PORT DISCR1PTIONS 

4.1 Serial Communications Port A — - See Appendix A 

00 Read/Write SIO Channel A Data port 

01 Read/Write SIO Channel A Status/Contiol Port 

4.2 Serial Communications Pott B See Appendex A 

02 Read/Write SIO Channel B Data port 

03 Read/Write SIO Channel B Status/Control Pott 

4.3 Par ailed Interface Pott A See Appendix B 

04 Read/Write PIO Channel A Data pott 

06 Write PIO Channel A Control Pott 

4.4 Parallel Interface Port B See Appendix B 

This port can be jumpered via jumpers E thtough P to the 

S100 Vectored Interrupt lines or to connector J2 (see sec 6.0 ) 

05 Read/Write PIO Channel B Data port 

07 Write PIO Channel B Control Port 

4.5 Control Tinuuer Interrupt circuit See Appendix C 

08 Read/Write CTC Channel Control Pott 

09 Read/Write CTC Channel 1 Control Pott 
0A Read/Write CTC Channel 2 Conttol Pott 
0B Read/Write CTC Channel 3 Conttol Pott 

4.6 Floppy Disk Controller See Appendix D 

0C Read/Write FDC Command/States Port 

0D Read/Write FDC Track Register 

0E Read/Write FDC Sector Register 

0F Read/Write FDC Data Port 
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4.7 Floppy Disk Control Port 

14 Read/Write FDC Syncronization/Dr ive/Density 

Port Read : 
CC 

When the cpu reads this port the cpu is placed into e wait 

state until a data byte can be transfered to or from the floppy 

disk controller or untill the command complete/terminate status 

(INTRQ) is set by the floppy disk controller. The floppy disk 

controller INTRQ status bit is placed on the data bus as bit D7 . 

This bit can be tested to determine if data is to be transfered 

of if the command is complete. 



+ + + + + + + + + 

• D7 • D6 ! D5 ! D4 ! D3 ! D2 ! Dl ! DO ! 
+ + + + + + + + + 

■ •!!!!!! 



D7 = MSB, D0 = LSB 



! + — Don' t care 

+ Don't care 

Don't care 

Don't care 

Don't care 

Don't care 



j + Don't care 

+ INTRQ* 0=active, l=inactive 

Port Write : 

The low two bits D0 and Dl of this port control which drive is 

selected. 



Dl 



D0 












1 


1 





1 


1 



Disk drive selected 
Disk drive 1 selected 
Disk drive 2 selected 
Disk drive 3 selected 
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Bit D3 sets the density mode. When bit D3 - 0, single density is 



selected. When bit D3 - 1 , double density is selected. 





























! 


D7 


I 


D6 


1 


D5 


i 


D4 


i 


D3 


« 


D2 


i Dl ! DO ! 




! . 

1 
1 




! 

i 

i 
i 








i 

! 

! 

1 
i 




i 

! 
i 

• 




1 
i 

• 

I 


! i 
• 4- — 
+ 




• 




• 
! 

1 

i 


















! 

1 






! 






































• 



















































D7 « MSB, D0 = LSB 



Disk drive select bit D0 
Disk drive select bit Dl 
SIDE SELECT, 0=HEAD 0,1=HEAD 
Density, 0=single, l=double 
Don't care 
Don* t care 
Don 1 t care 
Don't care 



4.8 Extended address port See Section 8.1 (buss defination) 

15 Write S100 Buss Extended Address A16-A23 

pott Write : 

This port controls the S100 Extended address lines. 

D7 = MSB, D0 * LSB 



4 4. 4 4- + 4- — 4- 4- 4- 

! D7 I D6 ! D5 ! D4 ! D3 ! D2 i Dl ! DO ! 

4 4 + 4- + + + 4- + 



4- — A16 

A17 

A18 

A19 

A20 

A21 

A22 

A23 
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4.9 On-Board Memory Control Port 

16 Write On-Board Memory Control Pott 

This port controls the onboard memory managment circuit, 

Prom enable and disable and power on jump reset circuits. 

Por L write : 

The four low order bits D0,D1,D2 and D3 switch the on board memoiy 

in 16k banks corresponding to address 0000h-3FFFh, 4000B-7FFFH, 

8000H-BFFFH and C000-FFFFH on and off. When a particular bank is 

switched off, external S100 memory can be accessed in that 

banks address range. This feature allows external memory to be 

added to the system for multi-user operating systems. 

Bit D5 of this port switches the on-board EPROM on and off. 

The onboard EPROM occupies address F000H-FFFFH. The EPROM 

is switched on automatically during reset or power on, the 

KPROM contains £10 and FDC initialization code along with a 

simple debugger and floppy disk cold start loader. After 

the operating system is loaded the EPROM can be turned off 

so that the ram at address F000H-FFFFH can be accessed. 

bit D6 reset the power on jump circuit. Bit D6 must be set 

high after a reset or power on situation before ram can 

be accessed. 

+ + + + h + \- + - + 

! D7 ! D6 I D5 I D4 i D3 1 D2 I Dl ! DO i D7 = MSB, D0 = LSB 
+ + + + 4- 4- + + + 



! ! ! 

! I ! 

! 1 ! 

I I i 

! I i 



! I I l=bank on, 0=bank off 
! I + — Memory Bank 0000H-3FFFH 

i + Memory Bank 4000H-7FFFH 

4 Memory Bank 8000H-BFFFH 

Menory Bank C000H-FBFFH 

i i 4 Don't care 

i + PROM enable=0, Disable=l 

4 power on jump reset=l 

j. Don't care 
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5.0 Jumper Definitions 

Jumper Function 



A CPU clock rate 2mhz/4mhz 

B Extemal/Enternal Tx/Rx clock foi SIO channel A 

C Extemal/Enternal Tx/Rx clock fot SIO channel B 

D Eight inch - five inch Drive selection 

E Select S100 interrupt vector line V10 OR PINT. 

p Select S100 interrupt vector VIO/PINT or Parallel 

Port B bit D0 on J 2-25. 
N Select S100 interrupt vector VII or Parallel 

Port B bit Dl on 3 2-21. 
M Select S100 interrupt vector VI2 or Parallel 

Port B bit D2 on J2-29. 
K Select S1G0 interrupt vector VI3 or Parallel 

Port B bit D3 on J2-31. 
J Select S100 interrupt vector V14 or Parallel 

Port B bit D4 on J 2-33. 
H Select S100 interrupt vector VI5 or Parallel 

Port B bit D5 on J2-35. 
G Select 5100 interrupt vector VIS or Parallel 

Port B bit D6 on J2-37. 
F Select S100 interrupt vector VI7 or Parallel 

Port B bit D7 on J2-39. 
R Select 2716 or 2732 EPROM. 
S Define floppy disk connector for eight ad five inch 

d r i v e s . 
T Enable / Disable £100 bus memory write signal on 

Jl - 68 

6.0 Jumper Descriptions 



6.1 A CPU clock rate 2mhz/4mhz 
This jumper determines the cpu clock rate. 
The jumper is located below IC U7 . 

+ + -J + 

1112 13! 
+ + * + 

Install Plug between posts 1 & 2 for 4mhz operation. 
Install Plug between posts 2 & 3 for 2mhz operation. 

6.2 B External/internal Tx/Rx clock for SIO channel A 
Jumper b connects the SIO channel A to either the internal baud rate 
generator or to the connector J4 pin 9 lor use in syctonous applications 
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Jumper B is located near J5. 

+ + 

1 1 ! 

+ + 

! 2 ! 

+ — -+ 

+ + 

Install Plug between posts 1 & 2 for external SIO clock. 



Connector J5 pin 9 

SIO Tx/Rx clock input 

Baud rate generator channel A 



Install Plug between posts 2 & 3 for Baud rate generator. 

6.3 C External/internal Tx/Rx clock for SIO channel B 

Jumper C connects the SIO channel B to either the internal baud rate 

generator or to connector J5 pin 9 for use in sycronous applications 

Jumper C is located near J5. 

+ + 

! 1 I Connector J5 pin 9 

+ + 

! 2 ! SIO Tx/Rx clock input 

+ + 

! 3 I Baud rate generator channel B 

+ + 

Install Plug between posts 1 & 2 for external SIO clock. 

Install Plug between posts 2 & 3 for Baud rate generator . 

6.4 D Eight inch - five inch Drive selection 
Jumper D is located near IC U2. 



+ + 

• 6 ! 

+ + 

! 5 ! 

+ + 

i 4 ! 
+ + 

! 3 ! 

+ + 

! 2 ! 

+ + 

! 1 ! 



8 inch floppy clock source 

FDC clock input 

5.25 inch floppy clock source 

5.25 head load/motor 

Head load source 

8 inch head load 



+ + 

Install Plug between posts 1 & 2 and 5 & 6 for 8 drives. 

Install Plug between posts 2 & 3 and 4 & 5 for 5.25 inch drives 
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Note : There ate other board modifications needed to interface 
the IDC to a 5.25 inch drive. 

6.5 E Select S100 interrupt vector line VI0 OR PINT. 
Jumper E selects the interrupt line to be used when channel B 
bit D0 is programmed for interrupts. 

Jumper E is located below IC U8. 

+ + + + 

1112 13 1 
+ + + + 

Install Plug between posts 1 & 2 for VI0 interrupt pin. (Jl-4) 
Install Plug between posts 2 & 3 for PINT interrupt pin. (Jl-73) 

6.6 P Select S100 interrupt vector VIO/PI.NT or Parallel 

Port B bit D0 on J2-25. 

This jumper is located near connector J2. 

+ + + + 

I 1 ! 2 ! 3 1 
+ + + + 

Install Plug between posts 1 & 2 to connect the PIO bit D0 

to J2 pin 25 (when the PIO bit is programmed for input/output) . 

Install Plug between posts 2 ft 3 to connect the PIO bit D0 

to the jumper selector area E, VI0/P1NT (when the PIO bit is 

programmed for interrupt m'ode) . 

6.7 N Select S100 interrupt vector Vll or Parallel 

Port B bit Dl on J2-27. 

This jumper is located near connector J2. 

+ + + + 

1112 13 1 

+ 4 + + 

Install Plug between posts 1 & 2 to connect the PIO bit Dl 

to J2 pin 25 (when the PIO bit is programmed for input/output). 

Install Plug between posts 2 & 3 to connect the PIO bit Dl 

to the vectored interrupt line VII (when the PIO bit is 

programmed for intetrupt mode). 
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6.8 M Select S100 interrupt vector VI2 or Parallel 

Port B bit D2 on J2-29. 
This jumper is located near connector J2. 

+ + + + 

! 1 ! 2 ! 3 I 
+ + + + 

Install Plug between posts 1 & 2 to connect the P10 bit D2 

to J2 pin 25 (when the PIO bit is programmed for input/output). 

Install Plug between posts 2 & 3 to connect the PIO bit D2 
to the vectored interrupt line VI2 (when the PIO bit is 
programmed for interrupt mode) . 

6.9 K Select S100 interrupt vector VI3 or Parallel 

Port B bit D3 on J2-31. 

This jumper is located near connector J2. 

+ + + + 

! 1 ! 2 ! 3 ! 
+ + + + 

Install Plug between posts 1 & 2 to connect the PIO bit D3 

to J2 pin 25 (when the PIO bit is programmed for input/output) . 

Install Plug between posts 2 & 3 to connect the PIO bit D3 
to the vectored interrupt line VI3 (when the PIO bit is 
programmed for interrupt mode) . 

6.10 J Select S100 interrupt vector VI4 oi Parallel 

Port B bit D4 on J2-33. 
This jumper is located near connector J2 . 

+ + + + 

! 1 ! 2 i 3 I 

+ + + + 

Install Plug between posts 1 & 2 to connect the PIO bit D4 

to J2 pin 25 (when the PIO bit is programmed for input/output) . 

Install Plug between posts 2 & 3 to connect the PIO bit D4 

to the vectored interrupt linr VI4 (when the PIO bit is 

programmed for interrupt mode). 

6.11 H Select S100 interrupt vector VI5 or Parallel 

Port B bit D5 on J2-35. 
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This jumper is located near connector 32. 

+ + + +. 

! 1 ! 2 ! 3 ! 
+ 1- + + 

Install Plug between posts 1 & 2 to connect the PIO bit D5 

to J2 pin 25 (when the PIO bit is programmed for input/output). 

Install Plug between posts 2 & 3 to connect the PIO bit D5 
to the vectored interrupt line V15 (when the PIO bit is 
programmed for interrupt mode). 

6.12 G Select S100 interrupt vector VI6 or Parallel 

Port B bit D6 on J2-37. 

This jumper is located near connector J2. 

> -i + + 

I 1 I 2 ! 3 i 

+ + + 4 

Install Plug between posts 1 & 2 to connect the PIO bit D6 

to J2 pin 25 (when the PIO bit is programmed for input/output) . 

Install Plug between posts 2 & 3 to connect the PIO bit D6 

to the vectored interrupt line VI6 (when the PIO bit is 

programmed for interrupt mode). 

6.13 t Select S100 interrupt vector VI7 or Parallel 

Port B bit D7 on J2-39. 

This jumper is located near connector 32. 

+ 1 v + 

« 1 ! 2 ! 3 I 

+ f f + 

Install Plug between posts 1 & 2 to connect the PIO bit D7 

to J2 pin 25 (when the PIO bit is programmed for input/output) . 

Install Plug between posts 2 & 3 to connect the PIO bit D7 
to the vectored interrupt line VI7 (when the PIO bit is 
programmed for interrupt mode). 

6.14 R Select 2716 or 2732 EPROM. 
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Jumper R configures the board to accept a 2716 or 2732 EPROM. 
Jumper R is located near the Z80 chip. 



+ + 

! 1 i 

+ + 

' 2 ' 

+ + 

i 3 i 

+ + 

Install Plug between posts 1 & 2 for a 2732 EPROM. 



Address line All 
EPROM input 
+5 volts 



Install Plug between posts 2 & 3 for a 2716 EPROM. 

Note : The EPROM is always addressed at F800H and can not 

be moved. Since the 2716 EPROM is 2K long it appears 
twice , F800H-FC00H and FBFFH-FFFFH. 



6.15 



Define floppy disk connector for eight , five inch 
drives and FDC chip type. 



This jumper is located U26. 

+ + + + 



i 1 



+ + y + 



! 4 



2 13! 



5 16 1 



+ + + + 

17 18 19 1 

+ + + + 

i 101 111 121 

For 8" set-up plug the following jumpers: 
lto4 ,2to3 ,5to6 r 7to8. 

For 5 1/4" plug the following jumpers: 

lto2 ,5to8 , 6to9 # 7tol0 , lltol2 . (see factory installed jumpers for 

additional jumpers or changes.) 
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6.16 T Enable / Disable S100 bus memory write signal on 

Jl - 68 
This jumper is located near U18 . 

+ + + 

1112 1 
+ + + 

Install Plug between posts 1 & 2 to connect the memory write 

signal (MEMWR) to the S100 bus pin 68. 

7.0 Baud Rate Switch 



The baud rate of the two serial channels can be select separately 

by setting the baud rate switch. The baud rate switch is an 8 

pole switch located near U54. It is split into two sections. 

Switches 1,2,3,4 set the baud rate for the S10 channel B and 

switches 5,6,7,8 set the baud rate for the SIO channel A. 

+ + OFF (up) 

SW1 !8i7!6!5!4i3!2ili 

+ + ON (down) 

<- Channel B -> <- Channel A -> 

7.1 Baud rate switch setting 

Switch 8 7 6 5 Channel B baud rate 
Switch 4 3 2 1 Channel A baud rate 

on on on on 50 

off on on on 75 

on off on on 110 

off off on on 134.5 

on on off on 150 

off on off on 300 

on off off on 600 

off off off on 1200 

on on on off 1800 

off on on off 2000 

on off on off 2400 

off off on off 3600 

on on off off 4800 

off on off off 7200 

on off off off 9600 

off off off off 19,200 
For exact baud rate frequencies see Appendix D 
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8.0 



External Connector Pin definitions 



8.1 Connector Jl - S100 bus connector 



PIN# 



NAME 



PIN # 



NAME 



1 


+8V 




51 


+8V 


2 


+ 16V 




52 


-16V 


3 


XRDY 




53 


GND 


4 


VI0* 




54 


SLAVE CLR* 


5 


VII* 




55-57 


DMAO*-DMA2* 


6 


VI2* 




58 


SXTRQ* 


7 


VI3* 




59 


A19 


8 


VI4* 




60 


SIXTN* 


9 


VI5* 




61-64 


A20-A23 


10 


VI6* 




65,65 


NDEF 


11 


VI7* 




67 


PHANTOM* 


12 


NMI* 




68 


MWRT 


13 


PWRFAIL* 




69 


RFU 


14 


DMA 3* 




70 


GND 


15 


A18 




71 


RFU 


16 


A17 




72 


RDY 


17 


A16 




73 


INT* 


18 


SDSB* 




74 


HOLD* 


19 


CDSB* 




75 


RESET* 


20 


GND 




76 


PSYNCH 


21 


NDEF 




77 


PWR* 


22 


ADSB* 




78 


PDBIN 


23 


DODSB* 




79-87 


A0-A11 


24 







88-95 


DO2-DI0 


25 


PSTVAL* 




96 


SINTA 


26 


PHLDA 




97 


SWO* 


27,28 


RFU 




98 


ERROR* 


29-34 


A5,A4,A3, 


r A15 


,A12,A9 




35 


DO 1 /DATA 


1 


99 


POC* 


36 


DO0/DATA 





100 


GND 


37 


A10 








38 


DO 4 








39 


D05 








40-43 


D06,DI2,DI3 r 


DI7 




44 


SMI 








45 


SOUT 








46 


SINP 








47 


SMEMR 








48 


SHLTA 








49 


CLOCK 








50 


GND 
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8.2 Connector J2 - Parallel port connector 



PIO Channel A ready signal 

ground 

PIO Channel A strobe 

ground 

PIO Channel A data bit D0 

ground 

PIO Channel A data bit Dl 

ground 

PIO Channel A data bit D2 

ground 

PIO Channel A data bit D3 

ground 

PIO Channel A data bit D4 

ground 

PIO Channel A data bit D5 

ground 

PIO Channel A data bit D6 

ground 

PIO Channel A data bit D7 

ground 

PIO Channel B ready signal 

ground 

PIO Channel B strobe 

ground 

PIO Channel B data bit D0 

ground 

PIO Channel B data bit Dl 

ground 

PIO Channel B data bit D2 

ground 

PIO Channel B data bit D3 

ground 

PIO Channel B data bit D4 

ground 

PIO Channel B data bit D5 

ground 

PIO Channel B data bit D6 

ground 

PIO Channel B data bit D7 



* Note : These pins can can be jumpered to the S100 bus 
vectored interrupt lines. 



1 


ARDY 


2 


ARDY RET 


3 


ASTRB* 


4 


ASTRB RET 


5 


PA0 




6 


PA0 


RET 


7 


PA1 




8 


PA1 


RET 


9 


PA2 




10 


PA2 


RET 


11 


PA3 




12 


PA3 


RET 


13 


PA4 




14 


PA4 


RET 


15 


PA5 




16 


PA5 


RET 


17 


PA6 




18 


PA6 


RET 


19 


PA7 




20 


PA7 


RET 


21 


BRDY 


22 


BRDY RET 


23 


BSTRB* 


24 


BSTRB RET 


25 


PB0 




26 


PB0 


RET 


27 


PB1 




28 


PB1 


RET 


29 


PB2 




30 


PB2 


RET 


31 


PB3 




32 


PB3 


RET 


33 


PB4 




34 


PB4 


RET 


35 


PB5 




36 


PB5 


RET 


37 


PB6 




38 


PB6 


RET 


39 


PB7 




40 


+ 5 


VOLTS 
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8.3 Connector J3 Floppy disk connector 
8 inch 5.25 inch 



1 




2 




3 




4 




5 




6 




i 




8 




9 




10 




11 




12 




13 




14 




15 




16 




17 


1 


18 


2 


19 


3 


20 


4 


21 


5 


22 


6 


23 


7 


24 


8 


25 


9 


26 


10 


27 


11 


28 


12 


29 


13 


30 


14 


31 


15 


32 


16 


33 


17 


34 


18 


35 


19 


36 


20 


37 


21 


38 


22 


39 


23 


40 


24 


41 


25 


4 2 


26 


43 


27 


44 


28 


45 


29 


46 


30 


47 


31 


48 


32 


49 


33 


50 


34 



ground 

Alternate Head 2* 

ground 

N/C 

ground 

N/C 

ground 

N/C 

ground 

N/C 

ground 

N/C 

ground 

Head 2* 

ground 

N/C 

ground 

Head load* 

ground 

Index* 

ground 

Ready* 

ground 

Above Track 43* 

ground 

Drive select 0* 

ground 

Drive select 1* 

ground 

Drive select 2* 

ground 

Drive select 3* 

ground 

Direction 

ground 

Step* 

ground 

Write Data* 

ground 

Wr i te gate* 

ground 

Track 0* 

ground 

Write protect* 

ground 

Read data* 

ground 

Motor on* 

ground 

N/C 



24 



8.4 Connector J4 



Serial port Channel A 



1 


N/C 


2 


DCDA* 


3 


SYNCA* 


4 


RxDA 


5 


CTSA* 


6 


TxDA 


7 


RTSA* 


8 


DTRA* 


9 


Tx/RxCA* 


10 


GND 


11 


N/C 


12 


+16 VOLTS 


13 


-16 VOLTS 


14 


+5 VOLTS 



Data Carrer Detect Channel 
Sync Detect 
Receive data 
Clear to send 
Transmit data 
Request to send 
Data terminal ready 
Transmitt / receive clock 



8.5 Connector J5 



Serial port Channel B 



1 


N/C 


2 


DCDA* 


3 


SYNCA* 


4 


RxDA 


5 


CTSA* 


6 


TxDA 


7 


RTSA* 


8 


DTRA* 


9 


Tx/RxCA* 


10 


GND 


11 


N/C 


12 


+16 VOLTS 


13 


-16 VOLTS 


14 


+5 VOLTS 



Data Carrer Detect Channel 
Sync Detect 
Receive data 
Clear to send 
Transmit data 
Request to send 
Data terminal ready 
Transmitt / receive clock 
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10.0 Factory Installed Jumpers 



10.1 Factory Installed jumpers for 8 inch floppy option 
Jumper 



A 


2-3 


CPU clock 4mhz 


B 


2-3 


Tx/Rx clock for SIO A internal 


C 


2-3 


Tx/Rx clock for SIO B internal 


D 


l-2 r 5-6 


Eight inch Drive selection 


E 


1-2 


Select vector line VI0 


F 


2-3 


Parallel Port B bit D0 on J2-25. 


G 


2-3 


Parallel Port B bit Dl on J2-27. 


H 


2-3 


Parallel Port B bit D2 on J2-29. 


J 


2-3 


Parallel Port B bit D3 on J2-31. 


K 


2-3 


Parallel Port B bit D4 on J2-33. 


M 


2-3 


Parallel Port B bit D5 on J2-35. 


N 


2-3 


Parallel Port B bit D6 on J2-37. 


P 


2-3 


Parallel Port B bit D7 on J2-39. 


R 


2-1 


Select 2716 


S 


1,2;2,3;5,6;7,8 


define floppy disk connector 


T 


1-2 


Enable S100 bus memory write sig 
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10.2 Factory Installed jumpers for 5.25 inch floppy option 
Jumper 



A 


2-3 


CPU clod 


t 4mh: 


z 






B 


2-3 


Tx/Rx clock for 


SIO A : 


internal 


C 


2-3 


Tx/Rx clock for 


SIO B 


internal 


D 


1-2,5-6 


Eight inch Drive selection 


E 


1-2 


Select vector 


1: 


Lne VI0 




F 


2-3 


Parallel 


Port 


B 


bit D0 


on J2-25 . 


G 


2-3 


Parallel 


Port 


B 


bit Dl 


on J2-27. 


H 


2-3 


Parallel 


Port 


B 


bit D2 


on J2-29. 


J 


2-3 


Parallel 


Port 


B 


bit D3 


on J2-31. 


K 


2-3 


parallel 


Port 


B 


bit D4 


on J2-33. 


M 


2-3 


Parallel 


Port 


B 


bit D5 


on J2-35. 


N 


2-3 


Parallel 


Port 


B 


bit D6 


on J2-37. 


P 


2-3 


Parallel 


Port 


B 


bit D7 


on J2-39. 


R 


2-1 


Select 2716 








S 


1,2;5,8;6,9;7,10;11 


,12 Define 


floppy 


disk connector 


T 


1-2 


Enable S100 bus 


memory 


write signal 



(to convert an 8 M board to 5 1/4" the following is required in addi- 
tion to the addendum) 
Capacitor C22 is changed to a 100pf or parallel a 47p£ with it. 
Capacitor C6 is changed to a 10mf. 
Resistor R4 is changed to 220k ohm 

Re-adjust the phase lock loop by adjusting the R26 pot. 
An easy way to adjust would be to put one trace of the scope on 
pin 7 of the u27(74sl24) and the other channel on a 2 MHZ. 
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10.3 



Shugart SA 800 Jumpers 



Disk drive jumpers 

Remove all jumpers on the disk drive. Install jumpers as follows 

Jumper Y. 
Jumper C 
Jumper T2 
Jumper Tl 
Jumper 800 
Jumper L 
Jumper A 
Jumper B 
Jumper DS 

10.4 Shugart 850 



Disk drive Jumpers 



10.6 



Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
DS1 for 



2S 
C 
A 
B 
R 
I 
Y 

850 
S2 
IT 
FS 
RM 
HL 
S 
M 

FM r MFM 
drive 



1 and DS2 for drive 
install termination at the end of 

MFE Model 700 



2 

cable 



Disk drive jumpers 
Install jumpers as follows 

C 



Jumper 


J3 


Jumper 


Jl-4,Jl-8 


Jumper 


RHL 


Jumper 


J10 


Jumper 


J4 


Jumper 


J7 


Jumper 


L-l 


Jumper 


SSI 


jumper 


J3 


Jumper 


SE2 


Jumper 


WP1 


Jumper 


J11,HS1 
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10.7 TANDON SLIM LINE 
Disk drive jumpers 

Install jumpers as follows: 

DS1 OR DS2 

INSTALL THE TERMINATION RES,. AT THE END OF THE CABLE 

10.8 NEC model FD1160 
Disk drive Jumpers 

Install jumpers as follows: 

Jumper C Jumper PRI 

Jumper N Jumper DLD 

Jumper HLS Jumper FU 
Jumper M 

10.9 QUME data track 8 
Disk drive jumpers 

Install jumpers as follows: 

DS1 OR DS2 
CUT X 
CUT Z 
CUT L 
INSTALL Y 
INSTALL C 

10.9.1 TANDON 5 1/4 " DRIVE (48TPI) 

Disk drive jumpers 

Install jumpers as follows: 

On the dip shunt header only pin2,7,8 are on. 

for DS1 and pins3,7,8 for DS2. 
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11.0 Appendex & Data sheets 



11.1 Appendex A - Z80A SIO / DART 
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Z8470Z8(TDART 
Dual Asynchronous 
Receiver/Transmitter 




Zilog 



Product 
Specification 



March 1981 



Features ■ Two independent full-duplex channels with 

separate modem controls. Modem status can 
be monitored. 

■ Receiver data registers are quadruply buf- 
fered; the transmitter is doubly buffered. 

■ Interrupt features include a programmable 
interrupt vector, a "status affects vector" 
mode for fast interrupt processing, and the 
standard Z-80 peripheral daisy-chain inter- 
rupt structure that provides automatic inter- 
rupt vectoring with no external logic. 



i In xl clock mode, data rates are to 500K 
bits/second with a 2.5 MHz clock, or to 
800K bits/second with a 4.0 MHz clock. 

Programmable options include 1 , 1 V2 or 2 
stop bits; even, odd or no parity; and xl, 
xl6, x32 and x64 clock modes. 

Break generation and detection as well as 
parity-, overrun- and framing-error detec- 
tion are available. 





s 



Description The Z-80 DART (Dual-Channel Asynchro- 

nous Receiver/Transmitter) is a dual-channel 
multi-function peripheral component that 
satisfies a wide variety of asynchronous serial 
data communications requirements in micro- 
computer systems. The Z-80 DART is used as a 
serial-to-parallel, parallel-to-serial converter/ 
controller in asynchronous applications. In 
addition, the device also provides modem con- 
trols for both channels. In applications where 



modem controls are not needed, these lines 
can be used for general- purpose I/O. 

Zilog also offers the Z-80 SIO, a more ver- 
satile device that provides synchronous 
(Bisync, HDLC and SDLC) as well as asyn- 
chronous operation. 

The Z-80 DART is fabricated with n-channel 
silicon-gate depletion-load technology, and is 
packaged in a 40-pin plastic or ceramic DIP. 



emi. 



0.— 

!>.♦■ 
0,-*- 

Of— 



KRET- 



KMO- 

R5- 



FT 



-RxM 

• ise* 

■ T>DA 

.T55X 

■ W/MWA 

■ sa 1 

■ HTSX 

-ens 



-•- nm 

— BCBX 



-NxOB 
-kTiCt 

• TlM 

-wmora 



► CH-» 



• era 

-OTRB 

-SEW 



Ncm-i 



+ SV QNO CLK 

Flgnr* 1. Z80 DART Pin Function 



BlC J 

»sC » 

D,C 4 

IBTC 5 

IB C « 

IEO C 7 

V00C • 

W/BbYA £ 10 

RlA C 11 *"' 

*«DA £ 12 

fSCA fj 13 

rax £ i« 

TlM £ IS 

BTBS C it 

Rf5*C ir 

erase 11 

sees c i» 

CLK fj 20 



3°. 

3°. 
3°. 

3 rasa 
]« 

]OND 

] wirovb 

] RiOB 
|] RiTkCI 
]T«DB 

JBtBb 

JfiTSB 

3ciII 

]B£&i 



Flgura 2. Pin AaBlgnnwnta 



2044-002,007 



89 



Pin B/A. Channel A Or B Select (input, High 

Description selects Channel B). This input defines which 
channel is accessed during a data transfer be- 
tween the CPU and the Z-80 DART. 

C/D. Control Or Data Select (input, High 
selects Control). This input specifies the type 
of information (control or data) transferred on 
the data bus between the CPU and the Z-80 
DART. 

CE. Chip Enable (input, active Low). A Low at 
this input enables the Z-80 DART to accept 
command or data input from the CPU during a 
write cycle, or to transmit data to the CPU 
during a read cycle. 

CLK. System Clock (input). The Z-80 DART 
uses the standard Z-80 single-phase system 
clock to synchronize internal signals. 

CTSA. CTSB. Clear To Send (inputs, active 
Low). When programmed as Auto Enables, a 
Low on these inputs enables the respective 
transmitter. If not programmed as Auto 
Enables, these inputs may be programmed as 
general-purpose inputs. Both inputs are 
Schmitt-trigger buffered to accommodate slow- 
risetime signals. 

D0-D7. System Data Bus (bidirectional, 
3-state) transfers data and commands between 
the CPU and the Z-80 DART. 



as an interrupt acknowledge if the Z-80 DART 
is the highest priority device that has inter- 
rupted the Z-80 CPU. 



DCDA, DCDB. Data Carrier Detect (inputs, 
active Low). These pins function as receiver 
enables if the Z-80 DART is programmed for 
Auto Enables; otherwise they may be used as 
general-purpose input pins. Both pins are 
Schmitt-trigger buffered. 



DTRA . DTRB. Data Terminal Beady (outputs, 
active Low). These outputs follow the state pro- 
grammed into the DTR bit. They can also be 
programmed as general- purpose outputs. 

IEI. Interrupt Enable In (input, active High) is 
used with IEO to form a priority daisy chain 
when there is more than one interrupt-driven 
device. A High on this line indicates that no 
other device of higher priority is being ser- 
viced by a CPU interrupt service routine. 

IEO. Interrupt Enable Out (output, active 
High). IEO is High only if IEI is High and the 
CPU is not servicing an interrupt from this 
Z-80 DART. Thus, this signal blocks lower 
priority devices from interrupting while a 
higher priority device is being serviced by its 
CPU interrupt service routine. 

INT. Interrupt Bequest (output, open drain, 
active Low). When the Z-80 DART is re- 
questing an interrupt, it pulls INT Low. 

Ml. Machine Cycle One (inp ut f rom Z-80 
CPU, active Low). When Ml and RD are both 
active, the Z-80 CPU is fetching an inst ructio n 
from memory; when Ml is active while IORQ is 
active, the Z-80 DART accepts Ml and IORQ 



IORQ. Input /Outpu t Bequest (input from CPU, 
active Low ). IO RQ is used in conjunction with 
B/A, C/D, CE and RD to transfer commands 
and data between the CPU and t he Z-80 
DART. When CE, RD and IORQ are all 
active, the channel selected by B/A transfers 
data to the CPU (a read operation). When CE 
and IORQ are active, but RD is inactive, the 
channel selected by B/A is written to by the 
CPU with eitherdata or control information as 
specified by C/D. 

RxCA. RxCB. Beceiver Clocks (inputs). 
Rece ive data is sampled on the rising edge of 
RxC. The Receive Clocks may be 1 , 16, 32 or 
64 times the data rate. 

RD. Bead C ycle Status, (input from CPU, ac- 
tive Low). If RD is active, a memory or I/O 
read operation is in progress. 

RxDA, RxDB. Beceive Data (inputs, active 
High). 



RESET. Beset (input, active Low). Disables 
both receivers and transmitters, forces TxDA 
and TxDB marking, forces the modem controls 
High and disables all interrupts. 

RIA , RIB. Bing Indicator (inputs , Ac tive 
Low) . These inputs are similar to CTS and 
DCD. The Z-80 DART detects both logic level 
transitions and interrupts the CPU. When not 
used in switched-line applications, these inputs 
can be used as general-purpose inputs. 



RTSA. RTSB. Bequest to Send (outputs, 

active Low). When the RTS bit is set, the RTS 
output goes Low. When the RTS bit is reset, 
the output goes High after the transmitter 
empties. 



TxCA. TxCB. Transmitter Clocks (inputs). TxD 
changes on the falling edge of TxC. The 
Transmitter Clocks may be 1, 16, 32 or 64 
times the data rate; however, the clock 
multiplier for the transmitter and the receiver 
must be the same. The Transmit Clock inputs 
are Schmitt-trigger buffered. Both the Receiver 
and Transmitter Clocks may be driven by the 
Z-80 CTC Counter Time Circuit for program- 
mable baud rate generation. 

TxDA. TxDB. Transmit Data (outputs, active 
High). 



W/RDYA. W/RDYB. Wait/Beady (outputs, 
open drain when programmed for Wait func- 
tion, driven High and Low when programmed 
for Ready function). These dual-purpose out- 
puts may be programmed as Ready lines for a 
DMA controller or as Wait lines that syn- 
chronize the CPU to the Z-80 DART data rate. 
The reset state is open drain. 
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Functional The functional capabilities of the Z-80 DART 

Description can be described from two different points of 
view: as a data communications device, it 
transmits and receives serial data, and meets 
the requirements of asynchronous data com- 
munications protocols; as a Z-80 family 
peripheral, it interacts with the Z-80 CPU and 
other Z-80 peripheral circuits, and shares the 
data, address and control buses, as well as 
being a part of the Z-80 interrupt structure. As 
a peripheral to other microprocessors, the Z-80 
DART offers valuable features such as non- 
vectored interrupts, polling and simple hand- 



shake capability. 

The first part of the following functional 
description introduces Z-80 DART data com- 
munications capabilities; the second part 
describes the interaction between the CPU and 
the Z-80 DART. 

A more detailed explanation of Z-80 DART 
operation can be found in the Z-80 SIO Tech- 
nical Manual (Document Number 03-3033-01). 
Because this manual was written for the 
Z-80 SIO, it contains information about syn- 
chronous as well as asynchronous operation. 



Communications CopabiUtiwi. The Z-80 
DART provides two independent full-duplex 
channels for use as an asynchronous 
receiver/transmitter. The following is a short 
description of receiver/transmitter capabilities. 
For more details, refer to the Asynchronous 
Mode section of the Z-80 SIO Technical 
Manual. The Z-80 DART offers transmission 
and reception of five to eight bits per 
character, plus optional even or odd parity. 
The transmitter can supply one, one and a half 
or two stop bits per character and can provide 
a break output at any time. The receiver break 
detection logic interrupts the CPU both at the 
start and end of a received break. Reception is 
protected from spikes by a transient spike re- 
jection mechanism that checks the signal one- 
half a bit time after a Low level is detected on 
the Receive Data input. If the Low does not 
persist — as in the case of a transient — the 
character assembly process is not started. 



Framing errors and overrun errors are 
detected and buffered together with the 
character on which they occurred. Vectored 
interrupts allow fast servicing of interrupting 
conditions using dedicated routines. Further- 
more, a built-in checking process avoids inter- 
preting a framing error as a new start bit: a 
framing error results in the addition of one-half 
a bit time to the point at which the search for 
the next start bit is begun. 

The Z-80 DART does not require symmetric 
Transmit and Receive Clock signals — a feature 
that allows it to be used with a Z-80 CTC or 
any other clock source. The transmitter and 
receiver can handle data at a rate of 1, 1/16, 
1/32 or 1/64 of the clock rate supplied to the 
Receive and Transmit Clock inputs. When 
using Channel B, the bit rates for transmit and 
rece ive o pera tions must be the sam e because 
RxC and TxC are bonded together (RxTxCB). 
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I/O Interface Capabilities. The Z-80 DART 
offers the choice of Polling, Interrupt (vectored 
or non- vectored) and Block Transfer modes to 
transfer data, status and control information to 



and from the CPU. The Block Transfer mode 
can be implemented under CPU or DMA 
control. 
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Functioned POLLING. There are no interrupts in the 

Description Polled mode. Status registers RRO and RR1 are 
(Continued) updated at appropriate times for each function 
being performed. All the interrupt modes of 
the Z-80 DART must be disabled to operate the 
device in a polled environment. 

While in its Polling sequence, the CPU 
examines the status contained in RRO for each 
channel; the RRO status bits serve as an 
acknowledge to the Poll inquiry. The two RRO 



status bits D and D 2 indicate that a data 
transfer is needed. The status also indicates 
Error or other special status conditions (see 
"Z-80 DART Programming"). The Special 
Receive Condition status contained in RR1 
does not have to be read in a Polling sequence 
because the status bits in RR1 are accom- 
panied by a Receive Character Available 
status in RRO. 



INTERRUPTS. The Z-80 DART offers an 
elaborate interrupt scheme that provides fast 
interrupt response in real-time applications. As 
a member of the Z-80 family, the Z-80 DART 
can be daisy-chained along with other Z-80 
peripherals for peripheral interrupt- priority 
resolution. In addition, the internal interrupts 
of the Z-80 DART are nested to prioritize the 
various interrupts generated by Channels A 
and B. Channel B registers WR2 and RR2 con- 
tain the interrupt vector that points to an inter- 
rupt service routine in the memory. To 
eliminate the necessity of writing a status 
analysis routine, the Z-80 DART can modify the 
interrupt vector in RR2 so it points directly to 
one of eight interrupt service routines. This is 
done under program control by setting a pro- 
gram bit (WR1, D 2 ) in Channel B called 
"Status Affects Vector." When this bit is set, 
the interrupt vector in RR2 is modified accord- 
ing to the assigned priority of the various 
interrupting conditions. 

Transmit interrupts, Receive interrupts and 
External/Status interrupts are the main sources 
of interrupts. Each interrupt source is enabled 
under program control with Channel A having 
a higher priority than Channel B, and with 
Receiver, Transmit and External/Status inter- 
rupts prioritized in that order within each 
channel. When the Transmit interrupt is 
enabled, the CPU is interrupted by the 
transmit buffer becoming empty. (This implies 
that the transmitter must have had a data 
character written into it so it can become 



empty.) When enabled, the receiver can inter- 
rupt the CPU in one of three ways: 

■ Interrupt on the first received character 

■ Interrupt on all received characters 

■ Interrupt on a Special Receive condition 

Interrupt On First Character is typically 
used with the Block Transfer mode. Interrupt 
On All Receive Characters can optionally 
modify the interrupt vector in the event of 
a parity error. The Special Receive Condition 
interrupt can occur on a character basis. The 
Special Receive condition can cause an inter- 
rupt only if the Interrupt On First Receive 
Character or Interrupt On All Receive Char- 
acters mode is selected. In Interrupt On First 
Receive Character, an interrupt can occur 
from Special Receive conditions (except Parity 
Error) after the first receive character interrupt 
(example: Receive Overrun interrupt). 

The main function of the External/Status 
interrupt i s to m onitor the signal transitions of 
the CTS , DCD and RI pins; however, an 
External/Status interrupt is also caused by the 
detection of a Break sequence in the data 
stream. The interrupt caused by the Break 
sequence has a special feature that allows the 
Z-80 DART to interrupt when the Break 
sequence is detected or terminated. This 
feature facilitates the proper termination of the 
current message, correct initialization of the 
next message, and the accurate timing of the 
Break condition. 



CPU/DMA BLOCK TRANSFER. The Z-80 
DART provides a Block Transfer mode to 
accommodate CPU block transfer functions 
and DMA block transfers (Z-80 DMA or other 
designs ) . The Block Transfer mode uses the 
W/RDY output in conjunction with the 
Wait/Re ady bits of Write Register 1 . The 
W/RDY output can be defined under software 
control as a Wait line in the CPU Block 



Transfer mode or as a Ready line in the DMA 
Block Transfer mode. 

To a DMA controller, the Z-80 DART Ready 
output indicates that the Z-80 DART is ready to 
transfer data to or from memory. To the CPU, 
the Wait output indicates that the Z-80 DART is 
not ready to transfer data, thereby requesting 
the CPU to extend the I/O cycle. 
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Internal The device internal structure includes a Z-80 

Architecture CPU interface, internal control and interrupt 
logic, and two full-duplex channels. Each 
channel contains read and write registers, and 
discrete control and status logic that provides 
the interface to modems or other external 
devices. 

The read and write register group includes 
five 8-bit control registers and two status 
registers. The interrupt vector is written into 
an additional 8-bit register (Write Register 2) 
in Channel B that may be read through Read 
Register 2 in Channel B. The registers for both 
channels are designated as follows: 

WR0-WR5 — Write Registers through 5 
RR0-RR2 — Read Registers through 2 

The bit assignment and functional grouping 
of each register is configured to simplify and 



organize the programming process. 

The logic for both channels provides for- 
mats, bit synchronization and validation for 
data transferred to and from the channel inter- 
face^ The modem control inp uts C lear to Send 
(CTS), Data_Carrier Detect (DCD) and Ring 
Indicator (RI ) are monitored by the control 
logic under program control. All the modem 
control signals are general purpose in nature 
and can be used for functions other than 
modem control. 

For automatic interrupt vectoring, the inter- 
rupt control logic determines which channel 
and which device within the channel has the 
highest priority. Priority is fixed with Channel 
A assigned a higher priority than Channel B; 
Receive, Transmit and External/Status inter- 
rupts are prioritized in that order within each 
channel. 



Data Path. The transmit and receive data path 
illustrated for Channel A in Figure 4 is iden- 
tical for both channels. The receiver has three 
8-bit buffer registers in a FIFO arrangement in 
addition to the 8-bit receive shift register. This 
scheme creates additional time for the CPU to 



service a Receive Character Available inter- 
rupt in a high-speed data transfer. 

The transmitter has an 8-bit transmit data 
register that is loaded from the internal data 
bus, and a 9- bit transmit shift register that is 
loaded from the transmit data register. 
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Read, 
Write and 
Interrupt 
Timing 



Read Cycle. The timing signals generated by 
a Z-80 CPU input instruction to read a Data or 



Status byte from the Z-80 DART are illustrated 
in Figure 5a. 



Write Cycle. Figure 5b illustrates the timing 
and data signals generated by a Z-80 CPU out- 



put instruction to write a Data or Control byte 
into the Z-80 DART. 



Interrupt Acknowledge Cycle. Afte r receiv- 
ing an Interrupt Request signal (INT pulled 
Low), the Z-80 CPU sends an Interr upt 
Acknowledge signal (Ml and IORQ both Low). 
The daisy-chained interrupt circuits determine 
the highest priority interrupt requestor. The IEI 
of the highest priority peripheral is terminated 
High. For any peripheral that has no interrupt 
pending or under service, IEO = IEI. Any 
peripheral that does have an interrupt pending 
or under service forces its IEO Low. 



To insure stable conditions in the daisy 
chain, all interrupt status signals are pr evente d 
from changing while Ml is Low. When IORQ is 
Low, the highest priority interrupt requestor 
(the one with IEI High) places its interrupt vec- 
tor on the data bus and sets its internal 
interrupt-under-service latch. 

Refer to the Z-80 SIO Technical Manual for 
additional details on the interrupt daisy chain 
and interrupt nesting. 



Return From Interrupt Cycle. Normally, the 
Z-80 CPU issues an RETI (Return From Inter- 
rupt) instruction at the end of an interrupt ser- 
vice routine. RETI is a 2-byte opcode (ED-4D) 
that resets the interrupt-under-service latch to 
terminate the interrupt that has just been 
processed. 



When used with other CPUs, the Z-80 DART 
allows the user to return from the interrupt 
cycle with a special command called "Return 
From Interrupt" in Write Register of Channel 
A. This command is interpreted by the Z-80 
DART in exactly the same way it would inter- 
pret an RETI command on the data bus. 



^X 


1 CHANNEL ADDRESS 


X 


CE 


v x, 


1 CHANNEL ADDRESS 


X 


/ 








P 


/ 


iomi 




/ 


A 


/ 


in — 












. 




r 


DATA 




zxz 


IN 


X 






J 



Figure 5a. Read Cycle 



Figure 5b. Write Cycle 



T 2 T w T w T 3 



iORO 



7 



f 



\ r 



— s: 

■^ vector)- 



T, T 2 T 3 T, T, T 2 T 3 T 4 T, 

JTJTJTnJTTLnJ"|J~Ln_ 

a r 




D -D 7 



<E> 



-G°> 



/ 



Figure 5c. Interrupt Acknowledge Cycle 



Figure 5d. Return from Interrupt Cycle 



94 



2044-008, 009, 010,011 



Z-80 DART To program the Z-80 DART, the system pro- 

Programming gram first issues a series of commands that 

initialize the basic mode and then other com- 
mands that qualify conditions within the select- 
ed mode. For example, the character length, 
clock rate, number of stop bits, even or odd 
parity are first set, then the Interrupt mode 
and, finally, receiver or transmitter enable. 



Both channels contain command registers 
that must be programmed via the system pro- 
gram prior to operation. The Channel Select 
input (B/A) and the Control/Data input (C/D) 
are the command structure addressing con- 
trols, and are normally controlled by the CPU 
address bus. 



Write Registers. The Z-80 DART contains six 
registers (WR0-WR5) in each channel that are 
programmed separately by the system program 
to configure the functional personality of the 
channels (Figure 4). With the exception of 
WRO, programming the write registers requires 
two bytes. The first byte contains three bits 
(D -D 2 ) that point to the selected register; the 
second byte is the actual control word that is 
written into the register to configure the Z-80 
DART. 

WRO is a special case in that all the basic 
commands (CMD -CMD 2 ) can be accessed 
with a single byte. Reset (internal or external) 
initializes the pointer bits D -D 2 to point to 
WRO. This means that a register cannot be 



pointed to in the same operation as a channel 
reset. 

Write Register Functions 

WRO Register pointers, initialization commands for 
the various modes, etc. 

WR1 Transmit/Receive interrupt and data transfer 
mode definition. 

WR2 Interrupt vector (Channel B only) 

WR3 Receive parameters and control 

WR4 Transmit/Receive miscellaneous parameters 
and modes 

WR5 Transmit parameters and controls 
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Read Registers. The Z-80 DART contains 
three registers (RR0-RR2) that can be read to 
obtain the status information for each channel 
(except for RR2, which applies to Channel B 
only). The status information includes error 
conditions, interrupt vector and standard 
communications-interface signals. 

To read the contents of a selected read 
register other than RRO, the system program 
must first write the pointer byte to WRO in 
exactly the same way as a write register opera- 
tion. Then, by executing an input instruction, 
the contents of the addressed read register can 
be read by the CPU. 



The status bits of RRO and RR1 are carefully 
grouped to simplify status monitoring. For 
example, when the interrupt vector indicates 
that a Special Receive Condition interrupt has 
occurred, all the appropriate error bits can be 
read from a single register (RR1). 

Read Register Functions 

RRO Transmit/Receive buffer status, interrupt 
status and external status 

RR1 Special Receive Condition status 

RR2 Modified interrupt vector (Channel B only) 
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Z-80 DART 
Read and Write 
Registers 
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WRITE REGISTER 
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WRITE REGISTER 1 
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11.2 Appendex B - Z80A PIO 



Z8420 

Z80 PIO Parallel 

Input/Output Controller 




Zilog 



Product 
Specification 



March 1981 



Features ■ Provides a direct interface between Z-80 

microcomputer systems and peripheral 
devices. 

■ Both ports have interrupt-driven handshake 
for fast response. 

■ Four programmable operating modes: byte 
input, byte output, byte input/output (Port A 
only), and bit input/output. 



Programmable interrupts on peripheral 
status conditions. 

Standard Z-80 Family bus- request and 
prioritized interrupt-request daisy chains 
implemented without external logic. 

The eight Port B outputs can drive Dar- 
lington transistors (1.5 mA at 1.5 V). 
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General 
Description 



The Z-80 PIO Parallel I/O Circuit is a pro- 
grammable, dual-port device that provides a 
TTL- compatible interface between peripheral 
devices and the Z-80 CPU. The CPU config- 
ures the Z-80 PIO to interface with a wide 
range of peripheral devices with no other 
external logic. Typical peripheral devices that 
are compatible with the Z-80 PIO include most 
keyboards, paper tape readers and punches, 
printers, PROM programmers, etc. 

One characteristic of the Z-80 peripheral 
controllers that separates them from other 
interface controllers is that all data transfer 
between the peripheral device and the CPU is 
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Figure 1. Pin Functions 



accomplished under interrupt control. Thus, 
the interrupt logic of the PIO permits full use 
of the efficient interrupt capabilities of the 
Z-80 CPU during I/O transfers. All logic 
necessary to implement a fully nested interrupt 
structure is included in the PIO. 

Another feature of the PIO is the ability to 
interrupt the CPU upon occurrence of speci- 
fied status conditions in the peripheral device. 
For example, the PIO can be programmed to 
interrupt if any specified peripheral alarm con- 
ditions should occur. This interrupt capability 
reduces the time the processor must spend in 
polling peripheral status. 
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General The Z-80 PIO interfaces to peripherals via 

Description two independent general-purpose I/O ports, 
(Continued) designated Port A and Port B. Each port has 
eight data bits and two handshake signals, 
Ready and Strobe, which control data transfer. 
The Ready output indicates to the peripheral 
that the port is ready for a data transfer. 
Strobe is an input from the peripheral that 
indicates when a data transfer has occurred. 

Operating Modes. The Z-80 PIO ports can be 
programmed to operate in four modes: byte 
output (Mode 0), byte input (Mode 1), byte 
input/output (Mode 2) and bit input/output 
(Mode 3). 

In Mode 0, either Port A or Port B can be 
programmed to output data. Both ports have 
output registers that are individually addressed 
by the CPU; data can be written to either port 
at any time. When data is written to a port, an 
active Ready output indicates to the external 
device that data is available at the associated 
port and is ready for transfer to the external 
device. After the data transfer, the external 
device responds with an active Strobe input, 
which generates an interrupt, if enabled. 

In Mode 1 , either Port A or Port B can be 
configured in the input mode. Each port has 
an input register addressed by the CPU. When 
the CPU reads data from a port, the PIO sets 
the Ready signal, which is detected by the 
external device. The external device then 
places data on the I/O lines and strobes the 
I/O port, which latches the data into the Port 
Input Register, resets Ready, and triggers the 
Interrupt Request, if enabled. The CPU can 
read the input data at any time, which again 
sets Ready. 

Mode 2 is bidirectional and uses Port A, 
plus the interrupts and handshake signals from 
both ports. Port B must be set to Mode 3 and 
masked off. In operation, Port A is used for 
both data input and output. Output operation 
is similar to Mode except that da ta is a llowed 
out onto the Port A bus only when ASTB is 
Low. For input, operation is similar to Mode 1 , 
except that the data input uses the Port B 
handshake signals and the Port B interrupt (if 
enabled) . 

Both ports can be used in Mode 3. In this 
mode, the individual bits are defined as either 
input or output bits. This provides up to eight 
separate, individually defined bits for each 
port. During operation. Ready and Strobe are 



not used. Instead, an interrupt is generated if 
the condition of one input changes, or if all 
inputs change. The requirements for gener- 
ating an interrupt are defined during the pro- 
gramming operation; the active level is 
specified as either High or Low, and the logic 
condition is specified as either one input active 
(OR) or all inputs active (AND). For example, 
if the port is programmed for active Low 
inputs and the logic function is AND, then all 
inputs at the specified port must go Low to 
generate an interrupt. 

Data outputs are controlled by the CPU and 
can be written or changed at any time. 

■ Individual bits can be masked off. 

■ The handshake signals are not used in 
Mode 3; Ready is held Low, and Strobe is 
disabled. 

■ When using the Z-80 PIO interrupts, the 
Z-80 CPU interrupt mode must be set to 
Mode 2. 




Figure 3. PIO in a Typical Z80 Family Environment 



46 



Internal The internal structure of the Z-80 PIO con- 

Structure sists of a Z-80 CPU bus interface, internal con- 

trol logic, Port A I/O logic, Port B I/O logic, 
and interrupt control logic (Figure 4). The 
CPU bus interface logic allows the Z-80 PIO to 
interface directly to the Z-80 CPU with no 
other external logic. The internal control logic 
synchronizes the CPU data bus to the per- 
ipheral device interfaces (Port A and Port B). 
The two I/O ports (A and B) are virtually 
identical and are used to interface directly to 
peripheral devices. 

Port Logic. Each port contains separate input 
and output registers, handshake control logic, 
and the control registers shown in Figure 5. 
All data transfers between the peripheral unit 
and the CPU use the data input and output 
registers. The handshake logic associated with 
each port controls the data transfers through 
the input and the output registers. The mode 
control register (two bits) selects one of the 
four programmable operating modes. 

The control mode (Mode 3) uses the remain- 
ing registers. The input/output control register 
specifies which of the eight data bits in the 
port are to be outputs and enables these bits; 
the remaining bits are inputs. The mask reg- 
ister and the mask control register control 
Mode 3 interrupt conditions. The mask register 
specifies which of the bits in the port are 
active and which are masked or inactive. 



The mask control register specifies two 
conditions: first, whether the active state of 
the input bits is High or Low, and second, 
whether an interrupt is generated when any 
one unmasked input bit is active (OR condi- 
tion) or if the interrupt is generated when 
all unmasked input bits are active (AND 
condition) . 

Interrupt Control Logic. The interrupt control 
logic section handles all CPU interrupt pro- 
tocol for nested-priority interrupt structures. 
Any device's physical location in a daisy-chain 
configuration determines its priority. Two lines 
(IEI and IEO) are provided in each PIO to 
form this daisy chain. The device closest to the 
CPU has the highest priority. Within a PIO, 
Port A interrupts have higher priority than 
those of Port B. In the byte input, byte output, 
or bidirectional modes, an interrupt can be 
generated whenever the peripheral requests a 
new byte transfer. In the bit control mode, an 
interrupt can be generated when the periph- 
eral status matches a programmed value. The 
PIO provides for complete control of nested 
interrupts. That is, lower priority devices may 
not interrupt higher priority devices that have 
not had their interrupt service routines com- 
pleted by the CPU. Higher priority devices 
may interrupt the servicing of lower priority 
devices. 
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Internal If the CPU (in interrupt Mode 2) accepts an 

Structure interrupt, the interrupting device must provide 

(Continued) an 8-bit interrupt vector for the CPU. This vec- 
tor forms a pointer to a location in memory 
where the address of the interrupt service 
routine is located. The 8-bit vector from the 
interrupting device forms the least significant 
eight bits of the indirect pointer while the 
I Register in the CPU provides the most signifi- 
cant eight bits of the pointer. Each port (A and 
B) has an independent interrupt vector. The 
least significant bit of the vector is automati- 
cally set to within the PIO because the 
pointer must point to two adjacent memory 
locations for a complete 16-bit address. 

Unlike the other Z-80 peripherals, the PIO 
does not enable interrupts i mm ediately after 
programming. It waits until Ml goes Low (e.g., 
during an opcode fetch). This condition is 
unimportant in the Z-80 environment but might 
not be if another type of CPU is used. 
The PIO decodes the RETI (Return From 



Interrupt) instruction directly from the CPU 
data bus so that each PIO in the system knows 
at all times whether it is being serviced by the 
CPU interrupt service routine. No other com- 
munication with the CPU is required. 

CPU Bus I/O Logic. The CPU bus interface 
logic interfaces the Z-80 PIO directly to the 
Z-80 CPU, so no external logic is necessary. 
For large systems, however, address decoders 
and/or buffers may be necessary. 

Internal Control Logic. This logic receives the 
control words for each port during program- 
ming and, in turn, controls the operating func- 
tions of the Z-80 PIO. The control logic syn- 
chronizes the port operations, controls the port 
mode, port addressing, selects the read/write 
function, and issues appropriate commands to 
the ports and the interrupt logic. The Z-80 PIO 
does not re ceive a w rite input from t he CPU; 
instead, the RD, CE, C/D and IORQ signals 
generate the write input internally. 
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Figure 5. Typical Port I/O Block Diagram 
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Programming Mode 0. 1. or 2. (Byte Input, Output, or 

Bidirectional). Programming a port for Mode 
0, 1, or 2 requires two words per port. These 
words are: 

A Mode Control Word. Selects the port operating mode 
(Figure 6). This word may be written any time. 

An Interrupt Vector. The Z-80 PIO is designed for use with 
the Z-80 CPU in interrupt Mode 2 (Figure 7). When inter- 
rupts are enabled, the PIO must provide an interrupt 
vector. 

Mode 3. (Bit Input/Output). Programming a 
port for Mode 3 operation requires a control 
word, a vector (if interrupts are enabled), and 
three additional words, described as follows: 

I/O Register Control. When Mode 3 is selected, the mode 
control word must be followed by another control word that 
sets the I/O control register, which in turn defines which 
port lines are inputs and which are outputs (Figure 8). 
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MODE SELECT 

MODEO 
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Interrupt Control Word. In Mode 3, handshake is not 
used. Interrupts are generated as a logic function of the 
input signal levels. The interrupt control word sets the 
logic conditions and the logic levels required for gener- 
ating an interrupt. Two logic conditions or functions are 
available: AND (if all input bits change to the active level, 
an interrupt is triggered), and OR (if any one of the input 
bits changes to the active level, an interrupt is triggered). 
Bit Dg sets the logic function, as shown in Figure 9. The 
active level of the input bits can be set either High or Low. 
The active level is controlled by Bit D5. 

Mask Control Word. This word sets the mask control 
register, allowing any unused bits to be masked off. If any 
bits are to be masked, then D4 must be set. When D4 is set, 
the next word written to the port must be a mask control 
word (Figure 10). 

Interrupt Disable. There is one other control 
word which can be used to enable or disable a 
port interrupt. It can be used without changing 
the rest of the interrupt control word 
(Figure 11). 
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Figure 6. Mod* Control Word 



Figure 9. Interrupt Control Word 
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Figure 7. Interrupt Vector Word 



Figure 10. Mask Control Word 
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Figure 8. I/O Register Control Word 



Figure 11. Interrupt Disable Word 
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Pin A0-A7. Port A Bus (bidirectional, 3-state). 

Description This 8-bit bus transfers data, status, or control 
information between Port A of the PIO and a 
peripheral device. Ao is the least significant 
bit of the Port A data bus. 

ARDY. Register A Heady (output, active 
High). The meaning of this signal depends on 
the mode of operation selected for Port A as 
follows: 

Output Mode. This signal goes active to indicate that the 
Port A output register has been loaded and the peripheral 
data bus is stable and ready for transfer to the peripheral 
device. 

Input Mode. This signal is active when the Port A input 
register is empty and ready to accept data from the 
peripheral device. 

Bidirectional Mode. This signal is active when data is 
available in the Port A output register for transfer to the 
peripheral device. In th is mod e, data is not placed on the 
Port A data bus, unless ASTB is active. 

Control Mode. This signal is disabled and forced to a Low 
state. 



ASTB. Port A Strobe Pulse From Peripheral 
Device (input, active Low). The meaning of 
this signal depends on the mode of operation 
selected for Port A as follows: 

Output Mode. The positive edge of this strobe is issued by 
the peripheral to acknowledge the receipt of data made 
available by the PIO. 

Input Mode. The strobe is issued by the peripheral to load 
data from the peripheral into the Port A input register. 
Data is loaded into the PIO when this signal is active. 

Bidirectional Mode. When this signal is active, data from 
the Port A output register is gated onto the Port A bidirec- 
tional data bus. The positive edge of the strobe acknowl- 
edges the receipt of the data. 

Control Mode. The strobe is inhibited internally. 

B0-B7. Port B Bus (bidirectional, 3-state). This 
8-bit bus transfers data, status, or control 
information between Port B and a peripheral 
device. The Port B data bus can supply 
1.5 mA at 1.5 V to drive Darlington transistors. 
Bo is the least significant bit of the bus. 

B/X. PortB Or A Select (input, High = B). 
This pin defines which port is accessed during 
a data transfer between the CPU and the PIO. 
A Low on this pin selects Port A; a High 
selects Port B. Often address bit Ao from the 
CPU is used for this selection function. 

BRDY. Register B Ready (output, active High). 
This signal is similar to ARDY, except that in 
the Port A bidirectional mode this signal is 
High when the Port A input register is empty 
and ready to accept data from the peripheral 
device. 



BSTB. Port B Strobe Pulse From Peripheral 
Device (i nput, a ctive Low). This signal is 
similar to ASTB, except that in the Port A 
bidirectional mode this signal strobes data 
from the peripheral device into the Port A 
input register. 



C/D". Control Or Data Select (input, 
High = C). This pin defines the type of data 
transfer to be performed between the CPU and 
the PIO. A High on this pin during a CPU 
write to the PIO causes the Z-80 data bus to be 
interpreted as a command for the port selected 
by the B/A Select line. A Low on this pin 
means that the Z-80 data bus is being used to 
transfer data between the CPU and the PIO. 
Often address bit A\ from the CPU is used for 
this function. 

CE. Chip Enable (input, active Low). A Low 
on this pin enables the PIO to accept com- 
mand or data inputs from the CPU during a 
write cycle or to transmit data to the CPU dur- 
ing a read cycle. This signal is generally 
decoded from four I/O port numbers for Ports 
A and B, data, and control. 
CLK. System Clock (input). The Z-80 PIO uses 
the standard single-phase Z-80 system clock. 

D0-D7. Z-80 CPU Data Bus (bidirectional, 
3-state). This bus is used to transfer all data 
and commands between the Z-80 CPU and the 
Z-80 PIO. Do is the least significant bit. 

IEI. Interrupt Enable In (input, active High). 
This signal is used to form a priority-interrupt 
daisy chain when more than one interrupt- 
driven device is being used. A High level on 
this pin indicates that no other devices of 
higher priority are being serviced by a CPU 
interrupt service routine. 

IEO. Interrupt Enable Out (output, active 
High). The IEO signal is the other signal 
required to form a daisy chain priority scheme. 
It is High only if IEI is High and the CPU is 
not servicing an interrupt from this PIO. Thus 
this signal blocks lower priority devices from 
interrupting while a higher priority device is 
being serviced by its CPU interrupt service 
routine. 

INT. Interrupt Req uest (output, open drain, 
active Low). When INT is active the Z-80 PIO 
is requesting an interrupt from the Z-80 CPU. 

IORQ. Input/Outp ut Req uest (input from Z-80 
CPU, active Low). I ORQ is used in conjunc- 
tion with B/A, C/D, CE, and RD to transfer 
commands and data between the Z-80 C PU and 
the Z-80 PIO. When CE, RD, and lORC} are 
active, the port addressed by B/A transfers 

data to the CP U (a rea d oper ation) . Con- 

versely, when CE and IORQ are_active but RD 
is not, the port addressed by B/A is written 
into from the CPU with either data or control 
information, as specified by C/D. Also, if 
IORQ and Ml are active simultaneously, the 
CPU is acknowledging an interrupt; the inter- 
rupting port automatically places its interrupt 
vector on the CPU data bus if it is the highest 
priority device requesting an interrupt. 
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Pin Ml. Machine Cycle (input from CPU, active 

Description Low). This signal is used as a sync pulse to 
(Continued) control several internal PIO operations. When 
both the Ml and RD signals are active, the 
Z-80 CPU is fetching an instruction from 
memo ry. Conversely, when both Ml and 
IORQ are active, the CPU is acknowledging 
an interrupt. In addition, Ml has two other 
functions within the Z-80 PIO: it synchronizes 



the PIO interrupt logic; when Ml occurs 
without an active RD or IORQ signal, the PIO 
is. reset. 

RD. Read Cyclejtatus (input from Z-80 CPU, 
active Low). If RD is active, or an I/0_opera- 
tion is in progr ess, RD is used with B/A, C/D, 
CE, and IORQ to transfer data from the Z-80 
PIO to the Z-80 CPU. 



Timing The following timing diagrams show typical 

timing in a Z-80 CPU environment. For more 
precise specifications refer to the composite 
ac timing diagram. 

Write Cycle. Figure 12 illustrates the 
timing for programming the Z-80 PIO 
or for writing data to one of its ports. No 
Wait states are allowed for writing to the 
PIO other than the automatically inserted 
TwA- The PIO does not receive a speci- 
fic write signal; it internally generates 
its own from the lack of an active 
RD signal. 
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Figure 12. Write Cycle Timing 





Read Cycle. Figure 13 illustrates the timing 
for reading the data input from an external 
device to one of the Z-80 PIO ports. No Wait 
states are allowed for reading the PIO other 
than the automatically inserted Twa- 

Output Mode (Mode 0). An output cycle 
(Figure 14) is always started by the exec ution 
of an output instruction by the CPU. The WR* 
pulse from the CPU latches the data from the 
CPU data bu s int o the selected port's output 
register. The WR* pulse sets the Ready flag 
after a Low-going edge of CLK, indicating 
data is available. Ready stays active until the 
positive edge of the . +robe line is received, 
indicating that data was taken by the periph- 
eral. The pos itive edge of the strobe pulse 
generates an INT if the interrupt enable flip- 
flop has been set and if this device has the 
highest priority. 
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*RD = RD • CE • C/D • IORQ 
Figure 13. Read Cycle Timing 




*WR = RD • CE • C/D • IORQ 

Figure 14. Mode Output Timing 
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Timing Input Mod* (Mode 1). When STROBE goes 

(Continued) Low, data is loaded into the selected port input 
register (Figure 15) . The next rising edge of 
strobe activates INT, if Interrupt Enable is set 
and this is the highest-priority requesting 
device. The following falling edge of CLK 
resets Ready to an inactive state, indicating 



that the input register is full and cannot accept 
any more data until the CPU completes a read. 
Wh en a read is complete, the positive edge of 
RD sets Ready at the next Low-going transition 
of CLK. At this time new data can be loaded 
into the PIO. 




*RD = RD • CE • C/D • IORQ 

Figure 15. Mode 1 Input Timing 



Bidirectional Mode (Mode 2). This is a com- 
bination of Modes and 1 using all four hand- 
shake lines and the eight Port A I/O lines 
(Figure 16). Port B must be set to the bit mode 
and its inputs must be masked. The Port A 
handshake lines are used for output control 
and the Port B lines are used for input control. 



If interrupts occur, Port A's vector will be used 
during port output and Port B's will be used 
during port input. Dat a is al lowed out onto the 
Port A bus only when ASTB is Low. The rising 
edge of this strobe can be used to latch the 
data into the peripheral. 




*WR = RD • CE • C/D • IORQ 

Figure 16. Mode 2 Bidirectional Timing 
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Timing Bit Mode (Mode 3). The bit mode does not 

(Continued) utilize the handshake signals, and a normal 

port write or port read can be executed at any 
time. When writing, the data is latched into 
the output registers with the same timing as the 
output mode (Figure 17). 

When reading the PIO, the data returned to 
the CPU is composed of output register data 
from those port data lines assigned as outputs 
and input register data from those port data 



lines assigned as inputs. The input register 
contains data that was pres ent immediately 
prior to the falling edge of RD. An interrupt is 
generated if interrupts from the port are 
enabled and the data on the port data lines 
satisfy the logical equation defined by the 8-bit 
mask and 2- bit mask control registers. How- 
ever, if Port A is programmed in bidirectional 
mode, Port B does not issue an interrupt in bit 
mode and must therefore be polled. 
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Figure 17. Mod* 3 Bit Mode Timing 



Interrupt Acknowledge Timing. During Ml 
time, peripheral controllers are inhibited from 
changing their interrupt enable status, permit- 
ting the Interrupt Enable signal to ripple 
through the daisy chain. The periphera l with 
IEI High and IEO Low during INTACK places 
a preprogrammed 8- bit interrupt vector on the 
data bus at this time (Figure 18). IEO is held 
Low until a Return From Interrupt (RETI) 
instruction is executed by the CPU while IEI is 
High. The 2-byte RETI instruction is decoded 
internally by the PIO for this purpose. 
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Figure 18. Interrupt Acknowledge Timing 



Return From Interrupt Cycle. If a Z-80 per- 
ipheral has no interrupt pending and is not 
under service, then its IEO = IEI. If it has an 
interrupt under service (i.e., it has already 
interrupted and received an interrupt acknowl- 
edge) then its IEO is always Low, inhibiting 
lower priority devices from interrupting. If it 
has an interrupt pending which has not yet 
been acknowledged, IEO is Low unless an 
"ED" is decoded as the first byte of a 2-byte 
opcode (Figure 19). In this case, IEO goes 
High until the next opcode byte is decoded, 
whereupon it goes Low again. If the second 
byte of the opcode was a "4D," then the 
opcode was an RETI instruction. 

After an "ED" opcode is decoded, only the 
peripheral device which has interrupted and is 
currently under service has its IEI High and its 



IEO Low. This device is the highest-priority 
device in the daisy chain that has received an 
interrupt acknowledge. All other peripherals 
have IEI = IEO. If the next opcode byte 
decoded is "4D," this peripheral device resets 
its "interrupt under service" condition. 
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Figure 19. Return From Interrupt 
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Number Symbol 


Parameter 


Z-80PIO 
Mia Max 

(as) (n») 


Z-80APIO 
Mln Max 

(ns) (n») 


z-8ob nasi 

Mln Max 

(ns) (nt) 


Comment 


1 


TcC 


Clock Cycle Time 


400 


[1] 


250 


[1] 


165 


[1] 




2 


TwCh 


Clock Width (High) 


170 


2000 


105 


2000 


65 


2000 




3 


TwCl 


Clock Width (Low) 


170 


2000 


105 


2000 


65 


2000 




4 


TfC 


Clock Fall Time 




30 




30 




20 




5 


TrC 


Clock Rise Time 




30 




30 




20 




6 


TsCS(RI) 


CE, B/A, C/D to RD, 
IORQ 1 Setup Time 


50 




50 




50 




[6] 


7 


Th 


Any Hold Times for Specified 
Setup Time 




















8 


TsRI(C) 


RD, IORQ to Clock t Setup 
Time 


115 




115 




70 






9- 






















UJ 


10 


TdRI(DOs) 


RD, IORQ t to Data Out Float 
Delay 




160 




110 




70 




11 


TsDI(C) 
TdlO(DOI) 


Data In to Clock f Setup Time 


50 
340 




50 
160 




40 
120 




CL = 50 P F 


12 


IORQ 1 to Data Out Delay 
(INTACK Cycle) 


[3] 


13- 


-TsMl(Cr) 


Ml 1 to Clock t Setup Time 


-210— 




— 90- 




— 70- 










14 


TsMl(Cf) 


Ml t to Clock I Setup Time 
(Ml Cycle) 

















[8] 


15 


TdMl(IEO) 
TsIEI(IO) 
-TdlEI(IEOf)— 


Ml I to IEO 1 Delay (Interrupt 
Immediately Preceding Ml 1) 


140 


300 


140 


190 


100 


100 


15,7] 


16 


IEI to IORQ 1 Setup Time 
(INTACK Cycle) 


[7] 


17 
















loj 
CL = 50 pF 


18 


TdlEI(IEOr) 


IEI t to IEO t Delay (after ED 
Decode) 




210 




160 




160 


[5] 


19 


TcIO(C) 


IORQ t to Clock 1 Setup Time 
(To Activate READY on Next 
Clock Cycle) 


220 




200 




170 






20- 


- TdC(RDYr)— 


- Clock 1 to READY t Delay 


-200— 




-190— 




-170— 




[5] 

CL = 50 pF 


21 


TdC(RDYf) 


Clock 1 to READY t Delay 


150 




140 




120 




[5] 


22 


TwSTB 
TsSTB(C) 


STROBE Pulse Width 


150 
220 




150 
220 




120 
150 




[4] 


23 


STROBE t to Clock 1 Setup 
Time (To Activate READY on 
Next Clock Cycle) 


[5] 


24- 


-TdlO(PD) 

TsPD(STB) 


- IORQ t to PORT DATA Stable 
Delay (Mode 0) 
















260 


200 


230 


180 


190 


160 


[5] 


25 


PORT DATA to STROBE t 
Setup Time (Mode 1) 




26 


TdSTB(PD) 
-TdSTB(PDr)— 


STROBE 1 to PORT DATA 
Stable (Mode 2) 

-STROBE t to PORT DATA Float 
Delay (Mode 2) 




230 




210 




180 


[5] 


27 




200 




180 




160 


CL = 50 pF 


28 


TdPD(INT) 


PORT DATA Match to INT I 
Delay (Mode 3) 




540 




490 




430 




29 


TdSTB(INT) 


STROBE t to INT 1 Delay 




490 




440 




350 





N 

00 

e 

S 
o 



NOTES: 



H 



TcC = TwCh + TwCl + TrC + TfC. 

Increase TdRI(DO) by 10 ns for each 50 pF in 

up to 200 pF max. 

Increase TdlO(DOI) by 10 ns lor each 50 pF, increase in 

loading up to 200 pF max. 
4| For Mode 2: TwSTB > TsPD(STB). 
51 Increase these values by 2 ns for each 10 pF increase in 

loading up to 100 pF max. 



[6] TsCS(RI) may be reduced. However, the time subtracted 

from TsCS(RI) will be added to TdRI(DO). 
[7| 2.5 TcC > (N-2)TdIEI(IEOf) + TdMl(IEO) + TsIEI(IO) 

■t^TTL Buffer Delay, if any. 
[8] Ml must be active for a minimum of two clock cycles to 

reset the PIO. 
[9] Z80B PIO numbers are preliminary and subject to change. 
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Absolute Voltages on all inputs and outputs 

Maximum with respect to GND -0.3 V to +7.0 V 

Ratings Operating Ambient 

Temperature As Specified in 

Ordering Information 

Storage Temperature -65 °C to + 150°C 



Stresses greater than those listed under Absolute Maxi- 
mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition above those indicated in the operational sections 
of these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 



Test 
Conditions 



The characteristics below apply for the 
following standard test conditions, unless 
otherwise noted. All voltages are referenced to 
GND (0 V). Positive current flows into the 
referenced pin. Available operating 
temperature ranges are: 

■ 0°to +70°C, 

+ 5.25 V 



Ordering Information section. 

All ac parameters assume a load capacitance 
of 100 pF max. Timing references between two 
output signals assume a load difference of 
50 pF max. 



+ 4.75 V 



'cc 



■ -40°Cto +85°C, 

+ 4.75 V < V cc <; +5.25 V 

■ -55° to +125°C, 

+ 4.75 V < V cc s +5.5 V 

The product number for each operating 
temperature range may be found in the 




DC 


Symbol 


Parameter 


Min 


Max 


Unit 


Test Condition 


Charac- 
teristics 


V,LC 


Clock Input Low Voltage 


-0.3 


+ 0.45 


V 






V,HC 


Clock Input High Voltage 


Vcc-0.6 


+ 5.5 


V 






V,L 


Input Low Voltage 


-0.3 


+ 0.8 


V 






V,H 


Input High Voltage 


+ 2.0 


+ 5.5 


V 






Vol 


Output Low Voltage 




+ 0.4 


V 


Iol = 2.0 mA 




Vqh 


Output High Voltage 


+ 2.4 




V 


Iqh = -250 ^A 




Ili 


Input Leakage Current 


-10.0 


+ 10.0 


M 


0<Vin<Vcc 




h 


3-State Output/Data Bus Input Leakage Current 


-10.0 


+ 10.0 


i* 


0<Vin<Vcc 




he 


Power Supply Current 




100.0 


mA 


Voh = 1-5V 




loHD 


Darlington Drive Current 


-1.5 


3.8 


mA 


Rext = 390 




Over speci 


ied temperature and voltage range. 










Capacitanc 


e Symbol 


Parameter 


Min 


Max 


Unit 


Test Condition 




C 


Clock Capacitance 
Input Capacitance 




10 
5 


pF 
pF 


Unmeasured 
pins returned 
to ground 




C OUT 


Output Capacitance 




10 


P F 





Over specified temperature range; t 
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11.3 Appendex C - Z80A CTC 



Z8430 

Z80 CTC Counter/ 

Timer Circuit 




Zilog 



Product 
Specification 



March 1981 



Features ■ Four independently programmable 

counter/timer channels, each with a 
readable downcounter and a selectable 
16 or 256 prescaler. Downcounters are 
reloaded automatically at zero count. 

■ Three channels have Zero Count/Timeout 
outputs capable of driving Darlington 
transistors. 



Selectable positive or negative trigger 
initiates timer operation. 

Standard Z-80 Family daisy-chain interrupt 
structure provides fully vectored, prioritized 
interrupts without external logic. The CTC 
may also be used as an interrupt controller. 

Interfaces directly to the Z-80 CPU or — for 
baud rate generation— to the Z-80 SIC 



O 

H 



General The Z-80 CTC four-channel counter/timer 

Description can be programmed by system software for a 
broad range of counting and timing applica- 
tions. The four independently programmable 
channels of the Z-80 CTC satisfy common 
microcomputer system requirements for event 
counting, interrupt and interval timing, and 
general clock rate generation. 

System design is simplified because the CTC 
connects directly to both the Z-80 CPU and the 
Z-80 SIO with no additional logic. In larger 
systems, address decoders and buffers may be 
required. 

Programming the CTC is straightforward: 



each channel is programmed with two bytes; a 
third is necessary when interrupts are enabled. 
Once started, the CTC counts down, reloads 
its time constant automatically, and resumes 
counting. Software timing loops are completely 
eliminated. Interrupt processing is simplified 
because only one vector need be specified; the 
CTC internally generates a unique vector for 
each channel. 

The Z-80 CTC requires a single + 5 V power 
supply and the standard Z-80 single-phase 
system clock. It is fabricated with n-channel 
silicon-gate depletion- load technology, and 
packaged in a 28-pin plastic or ceramic DIP. 
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Figure 1. Pin Functions 



Figure 2. Pin Assignments 
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Functional The Z-80 CTC has four independent counter/ 

Description timer channels. Each channel is individually 
programmed with two words: a control word 
and a time-constant word. The control word 
selects the operating mode (counter or timer), 
enables or disables the channel interrupt, and 
selects certain other operating parameters. If 
the timing mode is selected, the control word 
also sets a prescaler, which divides the system 
clock by either 16 or 256. The time-constant 
word is a value from 1 to 256. 

During operation, the individual Counter 
channel counts down from the preset time con- 
stant value. In counter mode operation the 
counter decrements on each of the CLK/TRG 
input pulses until zero count is reached. Each 
decrement is synchronized by the system 
clock. For counts greater than 256, more than 
one counter can be cascaded. At zero count, 
the down- counter is automatically reset with 
the time constant value. 

The timer mode determines time intervals as 
small as 4 /is (Z-80A) or 6.4 ps (Z-80) without 
additional logic or software timing loops. Time 
intervals are generated by dividing the system 
clock with a prescaler that decrements 



a preset down-counter. 

Thus, the time interval is an integral mul- 
tiple of the clock period, the prescaler value 
(16 or 256) and the time constant that is preset 
in the down-counter. A timer is triggered auto- 
matically when its time constant value is pro- 
grammed, or by an external CLK/TRG input. 

Three channels have two outputs that occur 
at zero count. The first output is a zero- 
count/timeout pulse at the ZC/TO output. The 
fourth channel (Channel 3) does not have a 
ZC/TO output; interrupt reguest is the only 
output available from Channel 3. 

Th e second output is Interrupt Reguest 
(INT), which occurs if the channel has its 
interrupt enabled during programming. When 
the Z-80 CPU acknowledges Interrupt Reguest, 
the Z-80 CTC places an interrupt vector on the 
data bus. 

The four channels of the Z-80 CTC are fully 
prioritized and fit into four contiguous slots in 
a standard Z-80 daisy-chain interrupt struc- 
ture. Channel is the highest priority and 
Channel 3 the lowest. Interrupts can be 
individually enabled (or disabled) for each of 
the four channels. 



Architecture The CTC has four major elements, as shown 
in Figure 3. 

■ CPU bus I/O 

■ Channel control logic 

■ Interrupt logic 

■ Counter/timer circuits 

CPU Bus I/O. The CPU bus I/O circuit 
decodes the address inputs, and interfaces the 
CPU data and control signals to the CTC for 
distribution on the internal bus. 



Internal Control Logic. The CTC internal 
control logic controls overall chip operating 
functions such as the chip enable, reset, and 
read/write logic. 

Interrupt Logic. The interrupt control logic 
ensures that the CTC interrupts interface prop- 
erly with the Z-80 CPU interrupt system. The 
logic controls the interrupt priority of the CTC 
as a function of the IEI signal. If IEI is High, 
the CTC has priority. During interrupt 
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Figure 3. Functional Block Diagram 
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Architecture processing, the interrupt logic holds IEO Low, 
(Continued) which inhibits the interrupt operation on lower 
priority devices. If the IEI input goes Low, 
priority is relinquished and the interrupt logic 
drives IEO Low. 

If a channel is programmed to request an 
interrupt, the interrupt logic driv es IE O Low at 
the zero count, and generates an INT signal to 
the Z-80 CPU. When the Z-80CPU r espond s 
with interrupt acknowledge (Ml and IORQ), 
then the interrupt logic arbitrates the CTC 
internal priorities, and the interrupt control 
logic places a unique interrupt vector on the 
data bus. 

If an interrupt is pending, the interrupt logic 
holds IEO Low. When the Z-80 CPU issues a 
Return From Interrupt (RETI) instruction, each 
peripheral device decodes the first byte 
(ED i6). If the device has a pending interrupt, 
it raises IEO (High) for one Ml cycle. This 
ensures that all lower priority devices can 
decode the entire RETI instruction and reset 
properly. 



INTERNAL BUS 




Figure 4. Counter/Timer Block Diagram 

Counter/Timer Circuits. The CTC has four 
independent counter/timer circuits, each con- 
taining the logic shown in Figure 4. 

Channel Control Logic. The channel control 
logic receives the 8- bit channel control word 
when the counter/timer channel is pro- 
grammed. The channel control logic decodes 



the control word and sets the following 
operating conditions: 

■ Interrupt enable (or disable) 

■ Operating mode (timer or counter) 

■ Timer mode prescaler factor (16 or 256) 

■ Active slope for CLK/TRG input 

■ Timer mode trigger (automatic or CLK/TRG 
input) 

■ Time constant data word to follow 

■ Software reset 

Time Constant Register. When the counter/ 
timer channel is programmed, the time con- 
stant register receives and stores an 8-bit time 
constant value, which can be anywhere from 1 
to 256 (0 = 256). This constant is automatic- 
ally loaded into the down- counter when the 
counter/timer channel is initialized, and subse- 
quently after each zero count. 

Prescaler. The prescaler, which is used only 
in timer mode, divides the system clock fre- 
quency by a factor of either 16 or 256. The 
prescaler output clocks the down-counter dur- 
ing timer operation. The effect of the prescaler 
on the down-counter is a multiplication of the 
system clock period by 16 or 256. The pre- 
scaler factor is programmed by bit 5 of the 
channel control word. 

Down-Counter. Prior to each count cycle, the 
down-counter is loaded with the time constant 
register contents. The counter is then 
decremented one of two ways, depending on 
operating mode: 

■ By the prescaler output (timer mode) 

■ By the trigger pulses into the CLK/TRG 
input (counter mode) 

Without disturbing the down-count, the Z-80 
CPU can read the count remaining at any time 
by performing an I/O read operation at the 
port address assigned to the CTC channel. 
When the down-counter reaches the zero 
count, the ZC/TO output generates a positive- 
going pulse. When the interrupt is enabled, 
zero co unt also triggers an interrupt request 
signal (INT) from the interrupt logic. 
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Programming Each Z-80 CTC channel must be pro- 
grammed prior to operation. Programming 
consists of writing two words to the I/O port 
that corresponds to the desired channel. The 
first word is a control word that selects the 
operating mode and other parameters; the 
second word is a time constant, which is a 
binary data word with a value from 1 to 256. A 
time constant word must be preceded by a 
channel control word. 

After initialization, channels may be 
reprogrammed at any time. If updated control 
and time constant words are written to a chan- 
nel during the count operation, the count con- 
tinues to zero before the new time constant is 
loaded into the counter. 

If the interrupt on any Z-80 CTC channel is 
enabled, the programming procedure should 
also include an interrupt vector. Only one vec- 
tor is required for all four channels, because 
the interrupt logic automatically modifies the 
vector for the channel requesting service. 

A control word is identified by a 1 in bit 0. 
A in bit 2 indicates a time constant word is to 
follow. Interrupt vectors are always addressed 
to Channel 0, and identified by a in bit 0. 

Addressing. During programming, channels 
are addressed with the channel select pins CSj 
and CS2. A 2-bit binary code selects the 
appropriate channel as shown in the following 
table. 

Channel CSi CSq 












1 





1 


2 


1 





3 


1 


1 



Reset. The CTC has both hardware and soft- 
ware resets. The hardware reset terminates all 
down- counts and disables all CTC interrupts 
by resetting the interrupt bits in the control 
registers. In addition, the ZC/TO and Interrupt 
outputs go inactive, IEO reflects IEI, and 



D0-D7 go to the high- impedance state. All 
channels must be completely reprogrammed 
after a hardware reset. 

The software reset is controlled by bit 1 in 
the channel control word. When a channel 
receives a software reset, it stops counting. 
When a software reset is used, the other bits in 
the control word also change the contents of 
the channel control register. After a software 
reset a new time constant word must be Written 
to the same channel. 

If the channel control word has both bits Di 
and D2 set to 1 , the addressed channel stops 
operating, pending a new time constant word. 
The channel is ready to resume after the new 
constant is programmed. In timer mode, if 
D3 = 0, operation is triggered automatically 
when the time constant word is loaded. 

Channel Control Word Programming. The 

channel control word is shown in Figure 5. It 
sets the modes and parameters described 
below. 

Interrupt Enable. D7 en ables the interrupt, so 
that an interrupt output (INT) is generated at 
zero count. Interrupts may be programmed in 
either mode and may be enabled or disabled 
at any time. 

Operating Mode. D6 selects either timer or 
counter mode. 

Prescaler Factor. (Timer Mode Only). D5 

selects factor — either 16 or 256. 

Trigger Slope. D4 selects the active edge or 
slope of the CLK/TRG input pulses. Note that 
reprogramming the CLK/TRG slope during 
operation is equivalent to issuing an active 
edge. If the trigger slope is changed by a con- 
trol word update while a channel is pending 
operation in timer mode, the result is the same 
as a CLK/TRG pulse and the timer starts. 
Similarly, if the channel is in counter mode, 
the counter decrements. 
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Figure 5. Channel Control Word 
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Programming Trigger Mode (Timer Mode Only). D3 selects 
(Continued) the trigger mode for timer operation. When D3 
is reset to 0, the timer is triggered automatic- 
ally. The time constant word is programmed 
during an I/O write operation, which takes one 
machine cycle. At the end of the write opera- 
tion there is a setup delay of one clock period. 
The timer starts automatically (decrements) on 
the rising edge of the second clock pulse (T2) 
of the machine cycle following the write opera- 
tion. Once started, the timer runs contin- 
uously. At zero count the timer reloads 
automatically and continues counting without 
interruption or delay, until stopped by a reset. 

When D3 is set to 1 , the timer is triggered 
externally through the CLK/TRG input. The 
time constant word is programmed during an 
I/O write operation, which takes one machine 
cycle. The timer is ready for operation on the 
rising edge of the second clock pulse (T2) of 
the following machine cycle. Note that the first 
timer decrement follows the active edge of the 
CLK/TRG pulse by a delay time of one clock 
cycle if a minimum setup time to the rising 
edge of clock is met. If this minimum is not 
met, the delay is extended by another clock 
period. Consequently, for immediate trigger- 
ing, the CLK/TRG input must precede T2 by 
one clock cycle plus its minimum setup time. If 
the minimum time is not met, the timer will 
start on the third clock cycle (T3). 

Once started the timer operates contin- 
uously, without interruption or delay, until 
stopped by a reset. 

Time Constant to Follow. A 1 in D2 indicates 
that the next word addressed to the selected 
channel is a time constant data word for the 
time constant register. The time constant word 
may be written at any time. 

A in D2 indicates no time constant word is 
to follow. This is ordinarily used when the 
channel is already in operation and the new 
channel control word is an update. A channel 
will not operate without a time constant value. 
The only way to write a time constant value is 
to write a control word with D2 set. 



Software Reset. Setting Di to 1 causes a soft- 
ware reset, which is described in the Reset 
section. 

Control Word. Setting Do to 1 identifies the 
word as a control word. 

Time Constant Programming. Before a chan- 
nel can start counting it must receive a time 
constant word from the CPU. During program- 
ming or reprogramming, a channel control 
word in which bit 2 is set must precede the 
time constant word to indicate that the next 
word is a time constant. The time constant 
word can be any value from 1 to 256 (Figure 
6). Note that 00i6 is interpreted as 256. 

In timer mode, the time interval is controlled 
by three factors: 

■ The system clock period (<j>) 

■ The prescaler factor (P), which multiplies 
the interval by either 16 or 256 

■ The time constant (T), which is programmed 
into the time constant register 

Consequently, the time interval is the pro- 
duct of <j> x P x T. The minimum timer resolu- 
tion is 16 x <j> (4 us with a 4 MHz clock). The 
maximum timer interval is 256x<£x256 (16.4 ms 
with a 4 MHz clock). For longer intervals 
timers may be cascaded. 

Interrupt Vector Programming. If the Z-80 
CTC has one or more interrupts enabled, it 
can supply interrupt vectors to the Z-80 CPU. 
To do so, the Z-80 CTC must be pre-pro- 
grammed with the most- significant five bits of 
the interrupt vector. Programming consists of 
writing a vector word to the I/O port cor- 
responding to the Z-80 CTC Channel 0. Note 
that Do of the vector word is always zero, to 
distinguish the vector from a channel control 
word. Dj and D2 are not used in programming 
the vector word. These bits are supplied by 
the interrupt logic to identify the channel 
reguesting interrupt service with a unique 
interrupt vector (Figure 7). Channel has the 
highest priority. 
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Pin CE. Chip Enable (input, active Low). When 

Description enabled the CTC accepts control words, inter- 
rupt vectors, or time constant data words from 
the data bus during an I/O write cycle; or 
transmits the contents of the down-counter to 
the CPU during an I/O read cycle. In most 
applications this signal is decoded from the 
eight least significant bits of the address bus 
for any of the four I/O port addresses that are 
mapped to the four counter- timer channels. 

CLE. System Clock (input). Standard single- 
phase Z-80 system clock. 

CLK/TRG0-CLK/TRG3. External Clock/Timer 
Trigger (input, user-selectable active High or 
Low). Four pins corresponding to the four Z-80 
CTC channels. In counter mode, every active 
edge on this pin decrements the down-counter. 
In timer mode, an active edge starts the timer. 

CSq-CSi. Channel Select (inputs active High). 
Two-bit binary address code selects one of the 
four CTC channels for an I/O write or read 
(usually connected to Ao and Ai). 

D0-D7. System Data Bus (bidirectional, 
3-state). Transfers all data and commands 
between the Z-80 CPU and the Z-80 CTC. 




IEI. Interrupt Enable In (input, active High). 
A High indicates that no other interrupting 
devices of higher priority in the daisy chain 
are being serviced by the Z-80 CPU. 

IEO. Interrupt Enable Out (output, active 
High). High only if IEI is High and the Z-80 
CPU is not servicing an interrupt from any 
Z-80 CTC channel. IEO blocks lower priority 
devices from interrupting while a higher 
priority interrupting device is being serviced. 

INT. Interrupt Bequest (output, open drain, 
active Low). Low when any Z-80 CTC channel 
that has been programmed to enable interrupts 
has a zero-count condition in its down-counter. 



IORQ. Input/Output Request (input from CPU, 
active Low). Used with CE and RD to transfer 
data and channel control words between the 
Z-80 C PU an d the Z-80 CTC. During_a_write 
cycle, IORQ and CE are active and RD 
inactive. The Z-80 CTC does not receive a 
specific write signal; rather, it internally 
gen erates its own from the i nverse of an active 
RD signal. In a read cycle, IORQ, CE and RD 
are active; the contents of th e down -counter 
are read by the Z-80 CPU. If IORQ and Ml are 
both true, the CPU is acknowledging an inter- 
rupt request, and the highest priority inter- 
rupting channel places its interrupt vector on 
the Z-80 data bus. 

Ml. Machine Cycle One (i nput fr om CPU, 
active Low). When Ml and IORQ are active, 
the Z-80 CPU is acknowledging an interrupt. 
The Z-80 CTC then places an interrupt vector 
on the data bus if it has highest priorit y, a nd if 
a channel has requested an interrupt (INT). 

RD. Bead Cycle Status (i nput, a ctiv e Lo w). 
Used in conjunction with IORQ and CE to 
transfer data and channel control words 
between the Z-80 CPU and the Z-80 CTC. 



RESET. Beset (input active Low). Terminates 
all down- counts and disables all interrupts by 
resetting the interrupt bits in all control 
registers; the ZC/TO and the Interrupt outputs 
go inactive; IEO reflects IEI; D0-D7 go to the 
high- impedance state. 

ZC/TO0-ZC/TO2. Zero Count/Timeout (output, 
active High) . Three ZC/TO pins corresponding 
to Z-80 CTC channels 2 through (Channel 3 
has no ZC/TO pin). In both counter and timer 
modes the output is an active High pulse when 
the down-counter decrements to zero. 



Figure 8. A Typical Z-80 Environment 
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Timing Read Cycle Timing. Figure 9 shows read 

cycle timing. This cycle reads the contents of a 
down-counter without disturbing the count. 
During clock cycle T2, the Z-80 CPU initiates a 
read cycle by dr iving the following inputs 
Low: RD, IORQ, and CE. A 2-bit binary code 
at inputs CS] and CSo selects the channel to 
be read. Ml must be High to distinguish this 
cycle from an interrupt acknowledge. No addi- 
tional wait states are allowed. 



latched into the appropriate register with the 
rising edge of clock cycle Twa- No additional 
wait states are allowed. 
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Figure 9. Read Cycle Timing 

Write Cycle Timing. Figure 10 shows write 
cycle timing for loading control, time constant 
or vector words. 

The CTC does not have a write signal input, 
so it generates one internally when the read 
(RD) i nput is H igh during Tj . During T2 
IORQ and CE inputs are Low. Ml must be 
High to distinguish a write cycle from an inter- 
rupt acknowledge. A 2-bit binary code at 
inputs CS] and CSo selects the channel to be 
addressed, and the word being written is 
placed on the Z-80 data bus. The data word is 



Figure 11. Timer Mode Timing 

Timer Operation. In the timer mode, a 
CLK/TRG pulse input starts the timer (Figure 
1 1 ) on the second succeeding rising edge of 
CLK. The trigger pulse is asynchronous, and it 
must have a minimum width. A minimum lead 
time (210 ns) is reguired between the active 
edge of the CLK/TRG and the next rising edge 
of CLK to enable the prescaler on the follow- 
ing clock edge. If the CLK/TRG edge occurs 
closer than this, the initiation of the timer 
function is delayed one clock cycle. This cor- 
responds to the startup timing discussed in the 
programming section. The timer can also be 
started automatically if so programmed by the 
channel control word. 







Figure 12. Counter Mode Timing 
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Figure 10. Write Cycle Timing 



Counter Operation. In the counter mode, the 
CLK/TRG pulse input decrements the down- 
counter. The trigger is asynchronous, but the 
count is synchronized with CLK. For the 
decrement to occur on the next rising edge of 
CLK, the trigger edge must precede CLK by a 
minimum lead time as shown in Figure 12. If 
the lead time is less than specified, the count 
is delayed by one clock cycle. The trigger 
pulse must have a minimum width, and the 
trigger period must be at least twice the clock 
period. 

The ZC/TO output occurs immediately after 
zero count, and follows the rising CLK edge. 
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Interrupt The Z-80 CTC follows the Z-80 system inter- 

Operation rupt protocol for nested priority interrupts and 

return from interrupt, wherein the interrupt 
priority of a peripheral is determined by its 
location in a daisy chain. Two lines — IEI and 
IEO — in the CTC connect it to the system daisy 
chain. The device closest to the + 5 V supply 
has the highest priority (Figure 13). For addi- 
tional information on the Z-80 interrupt struc- 
ture, refer to the Z-80 CPU Product Specifica- 
tion and the Z-80 CPU Technical Manual. 



Figure 13. Daisy-Chain Interrupt Prtaritiwi 

Within the Z-80 CTC, interrupt priority is 
predetermined by channel number: Channel 
has the highest priority, and Channel 3 the 
lowest. If a device or channel is being serviced 
with an interrupt routine, it cannot be inter- 
rupted by a device or channel with lower 
priority until service is complete. Higher 
priority devices or channels may interrupt the 
servicing of lower priority devices or channels. 

A Z-80 CTC channel may be programmed to 
reguest an interrupt every time its down- 
counter reaches zero. Note that the CPU must 
be programmed for interrupt mode 2. Some 
time after the interrupt request, the CPU sends 
an interrupt acknowledge. The CTC interrupt 
control logic determines the highest priority 
channel that is requesting an interrupt. Then, 
if the CTC IEI input is High (indicating that it 
has priority within the system daisy chain) it 
places an 8-bit interrupt vector on the system 
data bus. The high-order five bits of this vector 



were written to the CTC during the program- 
ming process; the next two bits are provided 
by the CTC interrupt control logic as a binary 
code that identifies the highest priority chan- 
nel requesting an interrupt; the low-order bit 
is always zero. 

Interrupt Acknowledge Timing. Figure 14 
shows interrupt acknowledge timing. After an 
interrupt request, the Z-80 CPU s ends an inter- 
rupt acknowledge (Ml and IORQ). All chan- 
nels are inhibited from changing their inter- 
rupt request status when Ml i s activ e — about 
two clock cycles earlier than IORQ. RD is 
High to distinguish this cycle from an instruc- 
tion fetch. 

The CTC interrupt logic determines the 
highest priority channel requesting an inter- 
rupt. If the CTC interrupt enable input (IEI) is 
High, the highest priority interrupting channel 
within the CTC pla ces its interrupt vector on 
the data bus when IORQ goes Low. Two wait 
states (Twa) are automatically inserted at this 
time to allow the daisy chain to stabilize. Addi- 
tional wait states may be added. 

Return from Interrupt Timing. At the end of 

an interrupt service routine the RETI (Return 
From Interrupt) instruction initializes the daisy 
chain enable lines for proper control of nested 
priority interrupt handling. The CTC decodes 
the 2-byte RETI code internally and determines 
whether it is intended for a channel being ser- 
viced. Figure 15 shows RETI timing. 

If several Z-80 peripherals are in the daisy 
chain, IEI settles active (High) on the chip 
currently being serviced when the opcode 
ED i6 is decoded. If the following opcode is 
4Di6, the peripheral being serviced is released 
and its IEO becomes active. Additional wait 
states are allowed. 
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Figure 14. Interrupt Acknowledge Timing 



Figure 15. Return From Interrupt Timing 
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11.4 Appendex D - Floppy Disk controller .... 



GENERAL DESCRIPTION 

The FD179X are MOS LSI devices which perform the 
functions of a Floppy Disk Formatter/Controller in 
a single chip implementation. The FD179X, which 
can be considered the end result of both the FD1771 
and FD1781 designs, is IBM 3740 compatible in 
single density mode (FM) and System 34 compatible 
in Double Density Mode (MFM). The FD179X con- 
tains all the features of its predecessor the FD1771, 
plus the added features necessary to read/write and 
format a double density diskette. These include ad- 
dress mark detection, FM and MFM encode and de- 
code logic, window extension, and write precompen- 
satkxi. In order to maintain compatibility, the FD1771, 
FD1781. and FD179X designs were made as dose as 
possible with the computer interface, instruction set, 
and I/O registers being identical. Also, head load 

PIN OUTS 



control is identical. In each case, the actual pin as- 
signments vary by only a few pins from any one to 
another. 

The processor interface consists of an 8»bit bi- 
directional bus for data, status, and control word 
transfers. The FD179X is set up to operate on a mul- 
tiplexed bus with other bus-oriented devices. 

The FD179X is fabricated in N-channel Silicon Gate 
MOS technology and is TTL compatible on all inputs 
and outputs. The 1793 is identical to the 1791 except 
the DAL lines are TRUE for systems that utilize true 
data busses. 

The 1795/7 has a side select output for controlling dou- 
ble sided drives, and the 1792 and 1794 are "Single 
Density Only" versions of the 1791 and 1793. On these 
devices, DDEN must be left open. 



PIN 
NUMBER 


PIN NAME 


SYMBOL 


FUNCTION 


i 

19 

20 

21 

40 
COMPUTEF 

2 
3 
4 

5,6 

7-14 
24 


NO CONNECTION 


NC 
MR 

Vss 
Vcc 
Vdo 

WE 

CS 

RE 

AO, A1 

DALC-DAL7 
CLK 


Pin 1 is internally connected to a back bias 
generator and must be left open by the user. 

A logic low on this input resets the device and 
loads HEX 03 into the command register. The Not 
Ready (Status Bit 7) is reset during MR ACTIVE. 
When MR is brought to a logic high a RESTORE 
Command is executed, regardless of the state of 
the Ready signal from the drive. Also, HEX 01 is 
loaded into sector register. 

Ground 

+5V ±5% 

+ 12V±5% 

A logic low on this input gates data on the DAL 
into the selected register when CS is low. 

A logic low on this input selects the chip and ena- 
bles computer communication with the device. 

A logic low on this input controls the placement of 
data from a selected register on the DAL when C§ 
is low. 

These inputs select the register to receive/ 
transfer data on the DAL lines under RE and WE 
control: 

A1 A0 RE WE 
Status Reg Command Reg 

1 Track Reg Track Reg 

1 Sector Reg Sector Reg 
1 1 Data Reg Data Reg 

Eight bit inverted Bidirectional bus used for trans- 
fer of data, control, and status. This bus is receiver 
enabled by WE or transmitter enabled by RE. 

This input requires a free-running square wave 
clock for internal timing reference, 2 MHz for 8" 
drives, 1 MHz for mini-drives. 


MASTER RESET 

POWER SUPPLIES 
INTERFACE: 


WRITE ENABLE 


CHIP SELECT 


READ ENABLE 

REGISTER SELECT 
LINES 


DATA ACCESS LINES 
CLOCK 



PIN 
NUMBER 


PIN NAME 


SYMBOL 


FUNCTION 


38 


DATA REQUEST 


DRQ 


This open drain output indicates that the DR con- 
tains assembled data in Read operations, or the 
DR is empty in Write operations. This signal is 
reset when serviced by the computer through 
reading or loading the DR in Read or Write opera- 
tions, respectively. Use 10K pull-up resistor to +5. 


39 INTERRUPT 
REQUEST 

FLOPPY DISK INTERFACE: 


INTRQ 


This open drain output is set at the completion of any 
command and is reset when the STATUS register is 
read or the command register is written to. Use 10K 
pull-up resistor to +5. 


15 


STEP 


STEP 


The step output contains a pulse for each step. 


16 


DIRECTION 


DIRC 


Direction Output is active high when stepping in, 
active low when stepping out. 


17 


EARLY 


EARLY 


Indicates that the WRITE DATA pulse occurring 
while Early is active (high) should be shifted early 
for write precompensation. 


18 


LATE 


LATE 


Indicates that the write data pulse occurring while 
Late is active (high) should be shifted late for write 
precompensation. 


22 


TEST 


TEST 


This input is used for testing purposes only and 
should be tied to +5V or left open by the user un- 
less interfacing to voice coil actuated motors. 


23 


HEAD LOAD TIMING 


HLT 


When a logic high is found on the HLT input the 
head is assumed to be engaged. 


25 


READ GATE (1791/3) 


RG 


A high level on this output indicates to the data 
separator circuitry that a field of zeros (or ones) 
has been encountered, and is used for synchroni- 
zation. 


25 


SIDE SELECT OUTPUT 
(1795, 1797) 


SSO 


The logic level of the Side Select Output is directly 
controlled by the 'S' flag in Type II or III commands. 
When S = 1, SSO is set to a logic 1. When S = 0, 
SSO is set to a logic 0. The Side Select Output is only 
updated at the beginning of a Type II or III command. 
It is forced to a logic upon a MASTER RESET 
condition. 


26 
27 


READ CLOCK 


RCLK 


A nominal square-wave clock signal derived from 
the data stream must be provided to this input. 
Phasing (i.e. RCLK transitions) relative to RAW 
READ is important but polarity (RCLK high or low) 
is not. 

The data input signal directly from the drive. This 
input shall be a negative pulse for each recorded 
flux transition. 


RAW READ 


RAW READ 


28 


HEAD LOAD 


HLD 


The HLD output controls the loading of the 
Read-Write head against the media. 


29 


TRACK GREATER 
THAN 43 


TG43 


This output informs the drive that the Read/Write 
head is positioned between tracks 44-76. This output 
is valid only during Read and Write Commands. 




WRITE GATE 


WG 


This output is made valid before writing is to be 

performed on the diskette. 

i 




NUMBER 



31 



32 



33 



34 
35 
36 

37 



PIN NAME 

WRITE DATA 



READY 



WRITE FAULT 
VFO ENABLE 



TRACK 00 



INDEX PULSE 



WRITE PROTECT 



DOUBLE DENSITY 



SYMBOL 

WD 



READY 



WF/VFOE 



TRO0 

IP 

WPRT 

DDEN 



FUNCTION 

A 250 ns (MFM) or 500 ns (FM) pulse per flux 
transition. WD contains the unique Address marks 
as well as data and clock in both FM and MFM 
formats. 

This input indicates disk readiness and is sampled 
for a logic high before Read or Write commands 
are performed. If Ready is low the Read or Write 
operation is not performed and an interrupt is 
generated. Type I operations are performed re- 
gardless of the state of Ready. The Ready input 
appears in inverted format as Status Register bit 
7. 

This is a bi-directional signal used to signify writing 
faults at the drive, and to enable the external PLO 
data separator. When WG = 1, Pin 33 functions as 
a WF input. If WF = 0, any write command will im- 
mediately be terminated. When WG = 0, Pin 33 func- 
tions as a VFOE output. VFOE will go low during a 
read operation after the head has loaded and settled 
(HLT = 1). On the 1795/7, it will remain low until the 
last bit of the second CRC byte in the ID field. VFOE 
will then go high until 8 bytes (MFM) or 4 bytes (FM) 
before the Address Mark. It will then go active until 
the last bit of the second CRC byte of the Data Field. 
On the 1791/3, VFOE will remain low until the end of 
the Data Field. 

This input informs the FD179X that the Read/Write 
head is positioned over Track 00. 
This input informs the FD179X when the index hole 
is encountered on the diskette. 

This input is sampled whenever a Write Command 
is received. A logic low terminates the command 
and sets the Write Protect Status bit. 

This pin selects either s ingle or double density op- 
eration. When D DEN = 0, double density is 
selected. When DDEN = 1, single density is 
selected. This line must be left open on the 1792/4 



ORGANIZATION 

The Floppy Disk Formatter block diagram is illus- 
trated on page 5. The primary sections include the 
parallel processor interface and the Floppy Disk inter- 
face. 

Data Shift Register— This 8-bit register assembles 
serial data from the Read Data input (RAW READ) 
during Read operations and transfers serial data to 
the Write Data output during Write operations. 
Data Register— This 8-bit register is used as a hold- 
ing register during Disk Read and Write operations. 
In Disk Read operations the assembled data byte is 
transferred in parallel to the Data Register from the 
Data Shift Register. In Disk Write operations informa- 
tion is transferred in parallel from the Data Register 
to the Data Shift Register. 



When executing the Seek command the Data Regis- 
ter holds the address of the desired Track position. 
This register is loaded from the DAL and gated onto 
the DAL under processor control. 

Track Register— This 8-bit register holds the track 
number of the current Read/Write head position. It is 
incremented by one every time the head is stepped in 
(towards track 76) and decremented by one when the 
head is stepped out (towards track 00). The contents 
of the register are compared with the recorded track 
number in the ID field during disk Read, Write, and 
Verify operations. The Track Register can be loaded 
from or transferred to the DAL. This Register should 
not be loaded when the device is busy. 
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Sector Register (SR)— -This 8-bit register hotels the 
address of the desired sector position. The contents 
of the register are compared with the recorded sector 
number in the ID field during disk Read or Write op- 
erations. The Sector Register contents can be loaded 
from or transferred to the DAL. This register should 
not be loaded when the device is busy. 

Command Register (CR)— This 8-bit register holds 
the command presently being executed. This register 
should not be loaded when the device is busy unless 
the new command is a force interrupt. The command 
register can be loaded from the DAL, but not read 
onto the DAL. 

Status Register (STR)— This 8-bit register holds de- 
vice Status information. The meaning of the Status 
bits is a function of the type of command previously 
executed. This register can be read onto the DAL, 
but not loaded from the DAL. 
CRC Logic— This logic is used to check or to gener- 
ate the 16-bit Cyclic Redundancy Check (CRC). The 
polynomial is: G(x) = x' 8 + x 12 + x s + 1. 



The CRC includes all information starting with the 
address mark and up to the CRC characters. The 
CRC register is preset to ones prior to data being 
shifted through the circuit. 

Arithmetic/Logic Unit (ALU)— The ALU is a serial 
comparator, incrementer, and decrementer and is 
used for register modification and comparisons with 
the disk recorded ID field. 

Timing and Control— All computer and Floppy Disk 
Interface controls are generated through this logic. 
The internal device timing is generated from an ex- 
ternal crystal clock. 

The FD1 791/3 has two diff erent m odes o f opera tion 
according to the state of DDEN. When DDEN = 
double density (MFM) is assumed. When DDEN = 1, 
single density (FM) is assumed. 

AM Detector— The address mark detector detects 
ID, data and index address marks during read and 
write operations. 
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PROCESSOR INTERFACE 

The interface to the processor is acco mplished 
through the eight Data Acce ss Li nes (DAL) and as- 
sociated control signals. The DAL are used to trans- 
fer Data, Stat us, a nd Control words out of, or into the 
FD179X. The DAL are three state buffers that are en- 
abled as output drivers when Chip Select (CS) and 
Read Enable (RE) are active (low logic state) or act 
as input receivers when CS and Write Enable (WE) 
are active. 

When transfer of data with the Floppy Disk Controller 
is required by the host processor, the device address 
is decoded and CS is made low. The address bits A1 
and AO, com bined with the signals RE during a Read 
operation or WE during a Write operation are inter- 
preted as selecting the following registers: 

A1-A0 READ (RE) WRITE (WE) 





1 

1 
1 1 



Status Register 
Track Register 
Sector Register 
Data Register 



Command Register 
Track Register 
Sector Register 
Data Register 



During Direct Memory Access (DMA) types of data 
transfers between the Data Register of the FD179X 
and the processor, the Data Request (DRQ) output is 
used in Data Transfer control. This signal also ap- 
pears as status bit 1 during Read and Write opera- 
tions. 

On Disk Read operations the Data Request is acti- 
vated (set high) when an assembled serial input byte 
is transferred in parallel to the Data Register. This bit 
is cleared when the Data Register is read by the pro- 
cessor. If the Data Register is read after one or more 
characters are lost, by having new data transferred 
into the register prior to processor readout, the Lost 
Data bit is set in the Status Register. The Read op- 
eration continues until the end of sector is reached. 
On Disk Write operations the data Request is acti- 
vated when the Data Register transfers its contents 
to the Data Shift Register, and requires a new data 
byte. It is reset when the Data Register Is loaded 
with new data by the processor. If new data is not 
loaded at the time the next serial byte is required by 
the Floppy Disk, a byte of zeroes is written on the 
diskette and the Lost Data bit is set in the Status Re- 
gister. 

At the completion of every command an INTRQ is 
generated. INTRQ is reset by either reading the 
status register or by loading the command register 
with a new command. In addition, INTRQ is gener- 
ated if a Force Interrupt command condition is met. 

FLOPPY DISK INTERFACE 

The 1 7 9X has two modes of operati on according to the 
state of DDEN (Pin 37). When DDEN = 1 , single density 
is selected. In either case, the CLK input (Pin 24) is at 
2 MHz. However, when interfacing with the mini-floppy, 
the CLK input is set at 1 MHz for both single density and 
double density. When the clock is at 2 MHz, the stepping 
rates of 3, 6, 10, and 15 ms are obtainable. When CLK 
equals 1 MHz these times are doubled. 



HEAD POSITIONING 

Five commands cause positioning of the Read-Write 
head (see Command Section). The period of each 
positioning step is specified by the r field in bits 1 and 
of the command word. After the last directional 
step an additional 15 milliseconds of head settling 
time takes place if the Verify flag is set in Type I 
commands. Note t hat this time doubles to 30 ms for 
a 1 MHz clock. If TEST = 0, there is zero settling 
time. There is also a 15 ms head settling time if the E 
flag is set in any Type II or III command. 

The rates (shown in Table 1) can be applied to a 
Step-Direction Motor through the device interface. 

Step — A 2 f*s (MFM) or 4 /*s (FM) pulse is provided 
as an output to the drive. For every step pulse is- 
sued, the drive moves one track location in a direc- 
tion determined by the direction output. 

Direction (DIRC) — The Direction signal is active high 
when stepping in and low when stepping out. The Di- 
rection signal is valid 12 us before the first stepping 
pulse is generated. 

When a Seek, Step or Restore command is executed 
an optional verification of Read-Write head position 
can be performed by setting bit 2 (V = 1) in the 
command word to a logic 1. The verification operation 
begins at the end of the 15 millisecond settling time 
after the head is loaded against the media. The track 
number from the first encountered ID Field is com- 
pared against the contents of the Track Register. If 
the track numbers compare and the ID Field Cyclic 
Redundancy Check (CRC) is correct, the verify oper- 
ation is complete and an INTRQ is generated with no 
errors. The FD179X must find an ID field with correct 
track number and correct CRC within 5 revolutions of 
the media; otherwise the seek error is set and an 
INTRQ is generated. 

Table 1. STEPPING RATES 



CLK 


2 MHz 


2 MHz 


1 MHz 


1 MHz 


2 MHz 


1 MHz 


DDEN 





1 





1 


X 


X 


RtRO 


TEST=1 


TEST=1 


TESTM 


TEST=1 


TEST=0 


TEST=0 





3 ms 


3 ms 


6 ms 


6 ms 


184,.s 


36%is 


1 


6 ms 


6 ms 


12 ms 


12 ms 


190»iS 


380fiS 


1 


10 ms 


10 ms 


20 ms 


20 ms 


198ms 


396ps 


1 1 


15 ms 


15 ms 


30 ms 


30 ms 


208ns 


416ms 



The Head Load (HLD) output controls the movement 
of the read/write head against the media. HLD is ac- 
tivated at the beginning of a Type I command if the h 
flag is set (h = 1), at the end of the Type I command 
if the verify flag (V = 1), or upon receipt of any Type 
II or III command. Once HLD is active it remains ac- 
tive until either a Type I command is received with 
(h = and V = 0); or if the FD179X is in an idle state 
(non-busy) and 15 index pulses have occurred. 
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Head Load Timing (HLT) is an input to the FD179X 
which is used for the head engage time. When 
HLT = 1, the FD179X assumes the head is com- 
pletely engaged. The head engage time is typically 
30 to 100 ms depending on drive. The low to high 
transition on HLD is typically used to fire a.one shot. 
The output of the one shot is then used for'HLT and 
supplied as an input to the FD179X. 



HLOf- 






-50 TO 100ms- 



HLT (FROM ONE SHOT) 



HEAD LOAD TIMING 

When both HLD and HLT are true, the FD179X will 
then read from or write to the media. The "and" of 
HLD and HLT appears as a status bit in Type I 
status. 

In summary for the Type I commands: if h = and 
V = 0, HLD is reset. If h = 1 and V = 0, HLD is set at the 
beginning of the command and HLT is not sampled nor 
is there an internal 15 ms delay. If h = and V = 1, 
HLD is set near the end of the command, an internal 
15 ms occurs, and the FD179X waits for HLT to be 
true. If h = 1 and V = 1 , HLD is set at the beginning 
of the command. Near the end of the command, after 
all the steps have been issued, an internal 15 ms 
delay occurs and the FD179X then waits for HLT to 
occur. 

For Type II and III commands with E flag off, HLD is 
made active and HLT is sampled until true. With E 
flag on, HLD is made active, an internal 15 ms delay 
occurs and then HLT is sampled until true. 

DISK READ OPERATIONS 

Sector lengths of 128, 256, 512 or 1024 are o btaina- 
ble in either FM or MFM formats. For FM, DDEN 
should be placed to logical "1" For MFM formats, 
DDEN should be placed to a logical "0."' Sector 
lengths are determined at format time by a special 
byte in the "ID" field. If this Sector length byte in the 
ID field is zero, then the sector length is 128 bytes. If 
01 then 256 bytes. If 02, then 512 bytes. If 03, then 
the sector length is 1024 bytes. The number of sec- 
tors per track as far as the FD179X is concerned can 
be from 1 to 255 sectors. The number of tracks as far 
as the FD179X is concerned is from to 255 tracks. 
For IBM 3740 compatibility, sector lengths are 128 
bytes with 26 sectors per track. For System 34 com- 
patibility (MFM), sector lengths are 256 bytes/sector 
with 26 sectors/track; or lengths of 1024 bytes/sector 
with 8 sectors/track. (See Sector Length Table.) 

For re ad operations, the FD179X requires RAW 
READ Data (Pin 27) signal which is a 250 ns pulse 
per flux transition and a Read clock (RCLK) signal to 
indicate flux transition spacings. The RCLK (Pin 26) 
signal is provided by some drives but if not it may be 



derived externally by Phase lock loops, one shots, or 
counter techniques. In addition, a Read Gate Signal 
is provided as an output (Pin 25) which can be used 
to inform phase lock loops when to acquire syn- 
chronization. When reading from the media in FM. RG 
is made true when 2 bytes of zeroes are detected. 
The FD179X must find an address mark within the 
next 10 bytes; otherwise RG is reset and the search 
for 2 bytes of zeroes begins all over again. If an ad- 
dress mark is found within 10 bytes, RG remains true 
as long as the FD179X is deriving any useful informa- 
tion from the data stream. Similarly for MFM, RG is 
made active when 4 bytes of "00" or "FF" are de- 
tected. The FD179X must find an address mark 
within the next 16 bytes, otherwise RG is reset and 
search resumes. 

During read operations (WG = 0), the VFOE (Pin 33) 
is pro vided for phase lock loop synchronization. 
VFOE will go active when: 

a) Both HLT and HLD are True 

b) Settling Time, if programmed, has expired 

c) The 179X is inspecting data off the disk 

If WF/VFOE is not used, leave open or tie to a 10K 
resistor to +5. 

DISK WRITE OPERATION 

When writing is to take place on the diskette the 
Write Gate (WG) output is activated, allowing current 
to flow into the Read/Write head. As a precaution to 
erroneous writing the first data byte must be loaded 
into the Data Register in response to a Data Request 
from the FD179X before the Write Gate signal can be 

activated. 

Writing is inhibited when the Write Protect input is a 
logic low, in which case any Write command is im- 
mediately terminated, an interrupt is generated and 
the Write Protect status bit is set. The Write Fault in- 
put, when activated, signifies a writing fault condition 
detected in disk drive electronics such as failure to 
detect write current flow when the Write Gate is acti- 
vated. On detection of this fault the FD179X termi- 
nates the current command, and se ts the Write Fault 
bit (bit 5) in the Status Word. The Write Fault input 
should be made inactive when the Write Gate output 
becomes inactive. 

For write operations, the FD179X provides Write 
Gate (Pin 30) and Write Data (Pin 31) outputs. Write 
data co nsists of a series of 500 ns p ulses in FM 
(DDEN = 1) and 250 ns pulses in MFM (DDEN = 0). 
Write Data provides the unique address marks in 
both formats. 

Also during write, two additional signals are provided 
for write precompensation. These are EARLY (Pin 
17) and LATE (Pin 18). EARLY is active true when 
the WD pulse appearing on (Pin 30) is to be written 
early. LATE is active true when the WD pulse is to be 
written LATE. If both EARLY and LATE are low when 
the WD pulse is present, the WD pulse is to be written at 
nominal. Since write precompensation values vary from 
disk manufacturer to disk manufacturer, the actual 
value is determined by several one shots or delay lines 
which are located external to the FD179X. The write 
precompensation signals EARLY and LATE are valid 
for the duration of WD in both FM and MFM formats. 
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Whenever a Read or Write command (Type II or III) 
is received the FD179X samples the Ready input. If 
this input is logic low the command is not executed 
and an interrupt is generated. All Type I commands 
are performed regardless of the state of the Ready 
input. Also, whenever a Type II or III command is re- 
ceived, the TG43 signal output is updated. 

COMMAND DESCRIPTION 

The FD179X will accept eleven commands. Com- 
mand words should only be loaded in the Command 
Register when the Busy status bit is off (Status bit 0). 
The one exception is the Force Interrrupt command. 
Whenever a command is being executed, the Busy 
status bit is set. When a command is completed, an 
interrupt is generated and the Busy status bit is re- 
set. The Status Register indicates whether the com- 
pleted command encountered an error or was fault 
free. For ease of discussion, commands are divided 
into four types. Commands and types are sum- 
marized in Table 2. 



Table 2 COMMAND SUMMARY 



Table 4 FLAG SUMMARY 



BITS 


TYPE COMMAND 


7 


6 


5 


4 


3 2 10 


I 


Restore 














h V r, r„ 


I 


Seek 











1 


h V r, r„ 


I 


Step 








1 


u 


h V r, r„ 


I 


Step In 





1 





u 


h V r, r„ 


I 


Step Out 





1 


1 


u 


h V r, r, 


II 


Read Sector 


1 








m 


F 2 E F, 


II 


Write Sector 


1 





1 


m 


F 2 E F, ao 


III 


Read Address 


1 


1 








E 


III 


Read Track 


1 


1 


1 





E 


III 


Write Track 


1 


1 


1 


1 


E 


IV 


Force Interrrupt 


1 


1 





1 


I, I: I. lo 



TYPE II & III COMMANDS 



m = Multiple Record flag (Bit 4) 

m = 0, Single Record 
m = 1 , Multiple Records 

ap = Data Address Mark (Bit 0) 

ao = 0. FB (Data Mark) 

a» = 1, F8 (Deleted Data Mark) 

E = 15 ms Delay (2MHz) 

E = 1. 15 ms delay 

E = 0, no 15 ms delay 

(F 2 ) S = Side Select Flag (179 1/3 only) 

S = 0, Compare for Side 
S = 1r Compare for Side 1 

(Fi) C = Side Compare Flag (1791/3 o nly) 

C = 0, disable side select compare 
C = 1, enable side select compare 

(F,) S = Side Select Flag 
(Bit 1, 1795/7 only) 
S = Update SSO to 
S = 1 Update SSO to 1 

(F,) b = Sector Length Flag 
(Bit 3, 1975/7 only) 





Sector Length Field 






00 01 10 


11 


b = 


256 


512 


1024 


128 


b= 1 


128 


256 


512 


1024 



Note: Bits shown in TRUE form. 



Table 3 FLAG SUMMARY 



Table 5 FLAG SUMMARY 



TYPE I COMMANDS 



h = Head Load Flag (Bit 3) 

h = 1, Load head at beginning 
h = 0, Unload head at beginning 
V = Verify flag (Bit 2) 

V = 1, Verify on destination track 

V = 0, No verify 

t,t = Stepping motor rate (Bits 1-0) 

Refer to Table 1 for rate summary 

u = Update flag (Bit 4) 

u = 1, Update Track register 
u = 0. No update 



TYPE IV COMMAND 



li = Interrupt Condition flags (Bits 3-0) 

10=1. Not-Ready to Ready Transition 

11 = 1, Ready to Not-Ready Transition 

12 = 1. Index Pulse 

13 = 1. Immediate Interrupt 

I3 -Iq = 0. Terminate with no Interrupt 



TYPE I COMMANDS 

The Type I Commands include the Restore, Seek, 
Step, Step-in. and Step-Out commands. Each of the 
Type I Commands contains a rate field (ion), which 
determines the stepping motor rate as defined in 
Table 1. 
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The Type I Commands contain a head load flag (h) 
which determines if the head is to be loaded at the 
beginning of the command. If h = 1, the head is 
loaded at the beginning of the command (HLD output 
is made active). If h = 0, HLD is deactivated. Once 
the head is loaded, the head will remain engaged 
until the FD179X receives a command that specifi- 
cally disengages the head. If the FD179X is idle 
(busy = 0) for 15 revolutions of the disk, the head will 
be automatically disengaged (HLD made inactive). 

The Type I Commands also contain a verification (V) 
flag which determines if a verification operation is to 
take place on the destination track. If V = 1, a verifi- 
cation is performed, if V = 0, no verification is per- 
formed. 

During verification, the head is loaded and after an 
internal 15 ms delay, the HLT input is sampled. 
When HLT is active (logic true), the first encountered 
ID field is read off the disk. The track address of the 



ID field is then compared to the Track Register; if 
there is a match and a valid ID CRC, the verification 
is complete, an interrupt is generated and the Busy 
status bit is reset. If there is not a match but there is 
valid ID CRC, an interrupt is generated, and Seek 
Error Status bit (Status bit 4) is set and the Busy 
status bit is reset. If there is a match but not a valid 
CRC, the CRC error status bit is set (Status bit 3). 
and the next encountered ID field is read from the 
disk for the verification operation. If an ID field with a 
valid CRC cannot be found after four revolutions of 
the disk, the FD179X terminates the operation and 
sends an interrupt, (INTRQ). 

The Step, Step-in, and Step-Out commands contain 
an Update flag (U). When U = 1, the track register is 
updated by one for each step. When U = 0, the track 
register is not updated. 

On the 1795/7 devices, the SSO output is not affected 
during Type 1 commands, and an internal side com- 
pare does not take place when the (V) Verify Flag is 
on. 



QE} 





6 6 








TYPE I COMMAND FLOW 



TYPE I COMMAND FLOW 
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RESTORE (SEEK TRACK 0) 

Upon receipt of thi s comm and the Track 00 (TROO) 
input is sampled. If TROO is active low indicating the 
Read-Write head is positioned over track 0, the Track 
Register is l oaded with zeroes and an interrupt is 
generated. If TROO is not active low, stepping pulses 
(pins 15 to 16) at a ra te specified by the nro field are 
issued until the TROO input is activated. At this time the 
Track Register is l oaded with zeroes and an interrupt is 
generated. If the TROO input does not go active tow 
after 255 stepping pulses, the FD179X terminates op- 
eration, interrupts, and sets the Seek error status bit. 
A verification operation takes place if the V flag is 
set. The h bit allows the head to be loaded at the 
start of command. Note that the Restore command is 
executed when MR goes from an active to an inac- 
tive state. 




=> 



(imtho ^ 

«SCT BuSV J ' 



SEEK 

This command assumes that the Track Register con- 
tains the track number of the current position of the 
Read-Write head and the Data Register contains the 
desired track number. The FD179X will update the 
Track register and issue stepping pulses in the ap- 
propriate direction until the contents of the Track re- 
gister are equal to the contents of the Data Register 
(the desired track location). A verification operation 
takes place if the V flag is on. The h bit allows the 
head to be loaded at the start of the command. An 
interrupt is generated at the completion of the com- 
mand. 

STEP 

Upon receipt of this command, the FD179X issues 
one stepping pulse to the disk drive. The stepping 
motor direction is the same as in the previous step 
command. After a delay determined by thenro field, a 
verification takes place if the V flag is on. If the u flag is 
on, the Track Register is updated. The h bit allows the 
head to be loaded at the start of the command. An 
interrupt is generated at the completion of the command. 



STEP-IN 

Upon receipt of this command, the FD179X issues 
one stepping pulse in the direction towards track 76. 
If the u flag is on, the Track Register is incremented 
by one. After a delay determined by the rir» field, a 
verification takes place if the V flag is on. The h bit 
allows the head to be loaded at the start of the 
command. An interrupt is generated at the comple- 
tion of the command. 

STEP-OUT 

Upon receipt of this command, the FD179X issues 
one stepping pulse in the direction towards track 0. If 
the u flag is on, the Track Register is decremented by 
one. After a delay determined by the nro field, a ver- 
ification takes place if the V flag is on. The h bit al- 
lows the head to be loaded at the start of the com- 
mand. An interrupt is generated at the completion of 
the command. 

TYPE II COMMANDS 

The Type II Commands are the Read Sector and 
Write Sector commands. Prior to loading the Type II 
Command into the Command Register, the computer 
must load the Sector Register with the desired sector 
number. Upon receipt of the Type II command, the 
busy status Bit is set. If the E flag = 1 (this is the 
normal case) HLD is made active and HLT is sam- 
pled after a 15 msec delay. If the E flag is 0, the 
head is loaded and HLT sampled with no 15 msec 
delay. The ID field and Data Field format are shown 
on page 13. 

When an ID field is located on the disk, the FD179X 
compares the Track Number on the ID field with the 
Track Register. If there is not a match, the next en- 
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countered ID field is read and a comparison is again 
made. If there was a match, the Sector Number of 
the ID field is compared with the Sector Register. If 
there is not a Sector match, the next encountered ID 
field is read off the disk and comparisons again 
made. If the ID field CRC is correct, the data field is 
then located and will be either written into, or read 
from depending upon the command. The FD179X 
must find an ID field with a Track number. Sector 
number, side number, and CRC within four revolutions 
of the disk; otherwise, the Record not found status bit is 
set (Status bit 3) and the command is terminated with an 
interrupt. 



Sector Length Table 



Sector Length 
Field (hex) 



Number of Bytes 
in Sector (decimal) 



00 
01 
02 
03 



128 
256 

512 
1024 



I ENTER 1 




SET UR RESET OHO. LOST 

DATA. RECORD NOT FOUND • 

STATUS BITS 5 » • INTRO 



(INTRO y^_ 

RESET SUSY J 




COPY S FLAG TO ] 
iSOlNE<17»7 0NlV> | 







MO S 


^^s.see More 

>^ HAS ^s> 

ISMS* \ 

. EXPHED yS 




MO _^^ _ _ _\ 



^ 




fttmto. RESET aus*\ 

I SET WRITE FROTECW 



f TEST O THCP* IS NO ISMS 



Each of the Type II Commands contains an (m) flag 
which determines if multiple records (sectors) are to 
be read or written, depending upon the command. If 
m = 0, a single sector is read or written and an inter- 
rupt is generated at the completion of tiie command. 
Um«1, multiple records are read or written with the 
sector register internally updated so that an address 
verification can occur on the next record. The 
FD179X will continue to read or write multiple records 
and update the sector register until the sector regis- 



sinoe* moles>-w _J"2£LI£!I.. ,u jr_ 




SET RfCOMMtOT 



found/ 
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ter exceeds the number of sectors on the track or 
until the Force Interrupt command is loaded into the 
Command Register, which terminates the command 
and generates an interrupt. 

If the Sector Register exceeds the number of sectors 
on the track, the Record-Nbt-Found status bit will be 
set. 

The Type II commands also contain side select com- 
pare flags. When C = 0, no side comparison is made. 
When C = 1 , the LSB of the side number is read off the 
10 Field of the disk and compared with the contents of 
the (S) flag. If the S flag compares with the side number 
recorded in the ID field, the 179X continues with the 
ID search. If a comparison is not made within 5 index 
pulses, the interrupt line is made active and the Record- 
Not-Found status bit is set. 

The 1 795/7 READ SECTOR and WRITE SECTOR com- 
mands include a 'b' flag. The 'b' flag, in conjunction with 
the sector length byte of the ID Field, allows different 
byte lengths to be implemented in each sector. For IBM 
compatability, the 'b' flag should be set to a one. The 




D 



bead"" >v n ° 


"mi" 








TjrES 







C INTRO RESET BUS* A 

SET CRC ERROR J 




INTRO RESET BUSV 



s' flag allows direct control over the SSO Line (Pin 25) 
and is set or reset at the beginning of the command, 
dependent upon the value of this flag. 

READ SECTOR 

Upon receipt of the Read Sector command, the head 
is loaded, the Busy status bit set, and when an ID 
field is encountered that has the correct track 
number, correct sector number, correct side number, 
and correct CRC, the data field is presented to the 
computer. The Data Address Mark of the data field must 
be found within 30 bytes in single density and 43 bytes in 
double density of the last ID field CRC byte; if not. the 
Record Not Found status bit is set and the operation is 
terminated. 

When the first character or byte of the data field has 
been shifted through the DSR, it is transferred to the 
DR, and DRQ is generated. When the next byte is 
accumulated in the DSR, it is transferred to the DR 
and another DRQ is generated. If the Computer has 
not read the previous contents of the DR before a 
new character is transferred that character is lost and 




_p^iNTRO RESET BUSY A 




ACCORDING TO AOFIELO ■• 



TUMM ON WG ft WRITE 
12 BYTES OF ZEROS 



4 TO OSR SET ORO 



WRITE BYTE TO DISK 




u 



WRITE t •VTE 0? * 



TUflN OFF WO 



V 
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the Lost Data Status bit is set. This sequence con- 
tinues until the complete data field has been inputted 
to the computer. If there is a CRC error at the end of 
the data field, the CRC error status bit is set, and the 
command is terminated (even if it is a multiple record 
command). 

At the end of the Read operation, the type of Data 
Address Mark encountered in the data field is re- 
corded in the Status Register (Bit 5) as shown below: 

STATUS 
BIT 5 



1 


WRITE SECTOR 



Deleted Data Mark 
Data Mark 



Upon receipt of the Write Sector command, the head 
is loaded (HLD active) and the Busy status bit is set. 
When an ID field is encountered that has the correct 
track number, correct sector number, correct side num- 
ber, and correct CRC, a DRQ is generated. The FD179X 
counts off 1 1 bytes in single density and 22 bytes in 
double density from the CRC field and the Write Gate 
(WG) output is made active if the DRQ is serviced (i.e., 
the DR has been loaded by the computer). If DRQ has 
not been serviced, the command is terminated and the 
Lost Data status bit is set. If the DRQ has been ser- 
viced, the WG is made active and six bytes of zeros 
in single density and 12 bytes in double density are 
then written on tne disk. At mis time the Data Ad- 
dress Mark is then written on the disk as determined 
by the ao field of the command as shown below: 

ao Data Address Mark (Bit 0) 



Deleted Data Mark 
Data Mark 



The FD179X then writes the data field and generates 
DRQ's to the computer. If the DRQ is not serviced in 
time for continuous writing the Lost Data Status Bit is 
set and a byte of zeros is written on the disk. The 
command is not terminated. After the last data byte 
has been written on the disk, the two-byte CRC is 
computed internally and written on the disk followed 
by one byte of logic ones in FM or in MFM. The WG 
output is then deactivated. 

TYPE III COMMANDS 

READ ADDRESS 

Upon receipt of the Read Address command, the 
head is loaded and the Busy Status Bit is set. The 



next encountered ID field is then read in from the 
disk, and the six data bytes of the ID field are as- 
sembled and transferred to the DR, and a DRQ is 
generated for each byte. The six bytes of the ID field 
are shown below: 



TRACK 
AOOR 


SIDE 
NUMBER 


SECTOR 
AODRESS 


SECTOR 
LENGTH 


CRC 
1 


CRC 
2 


1 


2 


3 


4 


5 


6 



Although the CRC characters are transferred to the 
computer, the FD179X checks for validity and the 
CRC error status bit is set if there is a CRC error. 
The Track Address of the ID field is written into the 
sector register. At the end of the operation an inter- 
rupt is generated and the Busy Status is reset. 

READ TRACK 

Upon receipt of the Read Track command, the head 
is loaded and the Busy Status bit is set. Reading 
starts with the leading edge of the first encountered 
index pulse and continues until the next index pulse. 
As each byte is assembled it is transferred to the 
Data Register and the Data Request is generated for 
each byte. No CRC checking is performed. Gaps are 
included in the input data stream. The accumulation 
of bytes is synchronized to each Address Mark en- 
countered. Upon completion of the command, the in- 
terrupt is activated. RG is not activated during the 
Read Track Command. An internal side compare is not 
performed during a Read Track. 

WRITE TRACK 

Upon receipt of the Write Track command, the head 
is loaded and the Busy Status bit is set. Writing 
starts with the leading edge of the first encountered 
index pulse and continues until the next index pulse, 
at which time the interrupt is activated. The Data Re- 
quest is activated immediately upon receiving the 
command, but writing will not start until after the first 
byte has been loaded into the Data Register. If the 
DR has not been loaded by the time the index pulse 
is encountered the operation is terminated making 
the device Not Busy, the Lost Data Status Bit is set, 
and the Interrupt is activated. If a byte is not present 
in the DR when needed, a byte of zeros is substi- 
tuted. Address Marks and CRC characters are writ- 
ten on the disk by detecting certain data byte pat- 
terns in the outgoing data stream as shown in the 
table below. The CRC generator is initialized when 
any data byte from F8 to FE is about to be transfer- 
red from the DR to the DSR in FM or by receipt of 
F5 in MFM. 



GAP 
III 


ID 
AM 


TRACK 
NUMBER 


SIDE 
NUMBER 


SECTOR 
NUMBER 


SECTOR 
LENGTH 


CRC 

1 


CRC 
2 


GAP 
II 


DATA 
AM 


DATA FIELD 


CRC 
1 


CRC 
2 


ID FIELD 


DATA FIELD 



In MFM only, IDAM and DATA AM are preceded by three bytes of A1 with dock transition between bits 4 and 5 
missing. 
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I ENTER 1 



^f INTRO | 

^\ RESET BUSY J 




G^£ 




y^ DOES >. 

^ OS* tT ^ 


VES 


WRITE ? CRC 
CHARS Cl* FT 






JZ 






^r does ^s. 


WRITE FC 
CLK Dt 




<^dsr ' c .^" 




JC 






>^DOES ^v 

S DSK »0 FE >■ 
X. ORFgFB >^ 


WRITE f O F£ OR 
F»-FB CLK CT 


— ► 








white dsr 






-^ iNOE>M*R« ^ 


NO 
VES 






-^ OR BEEN ^> 


WRITE 
BYTE OF ZEROS 
SET DATA LOST 


- ► 












\ OSR F* >^ 


WRITE Al-INMFM 
WITH HISSING CLOCK 
NWTMLI2E CRC 




J^C 






./^ OOES \ 
^ OSR F« V 


WRITE CI* IN MFM 
WITH MISSING CLOCK * 


JC 






>^ooes ^s. 


"EM." 




r° 






(MUTE OSR 











TYPE IN COMMAND WRITE TRACK 



TYPE III COMMAND WRITE TRACK 

CONTROL BYTES FOR INITIALIZATION 



DATA PATTERN 
IN DR (HEX) 


FD179X INTERPRETATION 


FD1 791/3 INTERPRETATION 
IN MFM (ODER = 0) 


IN FM (DDEN = 1) 


00 thru F4 


Write 00 thru F4 with CLK = FF 


Write 00 thru F4, in MFM 


F5 


Not Allowed 


Write A1* in MFM, Preset CRC 


F6 


Not Allowed 


Write C2** in MFM 


F7 


Generate 2 CRC bytes 


Generate 2 CRC bytes 


F8 thru FB 


Write F8 thru FB, Clk = C7, Preset CRC 


Write F8 thru FB, in MFM 


FC 


Write FC with Clk = D7 


Write FC in MFM 


FD 


Write FD with Clk = FF 


Write FD in MFM 


FE 


Write FE, Clk = C7, Preset CRC 


Write FE in MFM 


FF 


Write FF with Clk = FF 


Write FF in MFM 



'Missing clock transition between bits 4 and 5 



*• Missing clock transition between bits 3 & 4 
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f ENTER J 



SET BUSY 

RESET STATUS 

BITS 2. 4. $ 






J 



TITEST-f NOOEtAY 
II TEST- 1 and OK- 1 MHZ. 30 MS DELAY 




<? 




3 



Read TrackMdcft»ss 
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RESET BUSY 
SETNTRO 
SETRNF 



3 




TRANSFER TRACK 

NUMBER TO SECTOR 

REGISTOR 


YES 






Jl 




^^ cnc ^\. 


SETCRC 
ERROR BIT 








1| NO 






I' 


) 








SET INTRO 
. RESET BUSY 





TYPE in COMMAND 

Read Track/Address 



TYPE IV COMMAND 

FORCE INTERRUPT 

This command can be loaded into the command re- 
gister at any time. If there is a current command 
under execution (Busy Status Bit set), the command 
will be terminated and an interrupt will be generated 
when the condition specified in -the lo through b field 
is detected. The interrupt conditions are shown be- 
low: 

lo = Not-Ready-To-Ready Transition 

h = Ready-To-Not-Ready Transition 

k = Every Index Pulse 

b = Immediate Interrupt (requires reset, see 
Note) 
NOTE: If lo - Is = 0, there is no interrupt generated but 
the current command is terminated and busy is 
reset. This is the only command that will enable 
the immediate intemjpt to clear on a subse- 
quent Load Command Register or Read Status 
Register. 

STATUS DESCRIPTION 

Upon receipt of any command, except the Force In- 
terrupt command, the Busy Status bit is set and the 
rest of the status bits are updated or cleared for the 
new command. If the Force Interrupt Command is 
received when there is a current command under 
execution, the Busy status bit is reset, and the rest of 
the status bits are unchanged. If the Force Interrupt 
command is received when there is not a current 
command under execution, the Busy Status bit is 
reset and the rest of the status bits are updated or 
cleared. In this case. Status reflects the Type I com- 
mands. 



The format of the Status Register is shown below: 



(BITS) 


7 


6 


5 


4 


3 


2 


1 





S7 


S6 


S5 


S4 


S3 


S2 


S1 


SO 



Status varies according to the type of command exe- 
cuted as shown in Table 6. 
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FORMATTING THE DISK 

(Refer to section on Type III commands for flow diag- 
rams.) 

Formatting the disk is a relatively simple task when 
operating programmed I/O or when operating under 
Formatting the disk is accomplished by positioning 
the R/W head over the desired track number and is- 
suing the Write Track command. Upon receipt of the 
Write Track command, the FD179X raises the Data 
Request signal. At this point in time, the user loads 
the data register with desired data to be written on 
the disk. For every byte of information to be written 
on the disk, a data request is generated. This sequ- 
ence continues from one index mark to the next 
index mark. Normally, whatever data pattern appears 
in the data register is written on the disk with a nor- 
mal clock pattern. However, if the FD179X detects a 
data pattern of F5 thru FE in the data register, this is 
interpreted as data address marks with missing 
clocks or CRC generation. For instance, in FM an FE 
pattern will be interpreted as an ID address mark 
(DATA-FE, CLK-C7) and the CRC will be initialized. 
An F7 pattern will generate two CRC characters in 
FM or MFM. As a consequence, the patterns F5 thru 
FE must not appear in the gaps, data fields, or ID 
fields. Also, CRC's must be generated by an F7 pat- 
tern. 

Disks may be formatted in IBM 3740 or System 34 
formats with sector lengths of 128. 256, 512, or 1024 
bytes. 



IBM 3740 FORMAT— 128 BYTES/SECTOR 

Shown below is the IBM single-density format with 
128 bytes/sector. In order to format a diskette, the 
user must issue the Write Track command, and load 
the data register with the following values. For ever) 
byte to be written, there is one data request. 



NUMBER 


HEX VALUE OF 


OF BYTES 


BYTE WRITTEN 


40 


FF (or 00)' 


6 


00 


1< 


FC (Index Mark) 


26 


FF (or 00) 


6 


00 


1 


FE (ID Address Mark) 


1 


Track Number 


1 


Side Number (00 or 01 ) 


1 


Sector Number (1 thru 1A) 


1 


00 


♦ 


F7 (2 CRC's written) 


11 


FF (or 00) 


6 


00 


t 


FB (Data Address Mark) 


128 


Data (IBM uses E5) 


1 


F7 (2 CRC's written) 


27 


FF (or 00) 


247* * 


FF (or 00) 



'Write bracketed field 26 times 

"Continue writing until FD179X interrupts out. 

Approx. 247 bytes. 
1 -Optional '00' on 1795/7 only. 
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IBM SYSTEM 34 FORMAT- 
256 BYTES/SECTOR 

Shown below is the IBM dual-density format with 256 
bytes/sector. In order to format a diskette the user 
must issue the Write Track command and load the 
data register with the following values. For every byte 
to be written, there is one data request. 



NUMBER 


HEX VALUE OF 


OF BYTES 


BYTE WRITTEN 


80 


4E 


12 


00 


3 


F6 


1 


FC (Index Mark) 


50* 


4E 




12 


00 




3 


F5 




1 
1 


FE (ID Address Mark) 
Track Number (0 thru 4C) 




1 


Side Number (0 or 1) 




1 
1 


Sector Number (1 thru 1A) 
01 




t 


F7 (2 CRCs written) 




22 


4E 




12 


00 




3 


F5 




1 


FB (Data Address Mark) 




256 
1 


DATA 

F7 (2 CRCs written) 




54 


4E 


598** 


4E 


* Write bracketed field 26 times 


"Continue writing until FD179X interrupts out. 


Approx. 598 bytes. 



1. NON-IBM FORMATS 

Variations in the IBM format are possible to a limited 
extent if the following requirements are met sector 
size must be a choice of 128, 256, 512, or 1024 bytes; 
gap size must be according to the following table. Note 
that the Index Mark is not required by the 179X. The 
minimum gap sizes shown are that which is required by 
the 179X, with PLL lock-up time, motor speed variation, 
etc., adding additional bytes. 





FM 


MFM 


Gapl 


16 bytes FF 


32 bytes 4E 


Gap II 


11 bytes FF 


22 bytes 4E 


• 


6 bytes 00 


12 bytes 00 
3 bytes A1 


Gap III 


10 bytes FF 


24 bytes 4E 
3 bytes A1 


*• 


4 bytes 00 


8 bytes 00 


Gap IV 


16 bytes FF 


16 bytes 4E 



•Byte counts must be exact. 
**Byte counts are minimum, except exactly 3 bytes 
of A1 must be written. 



ELECTRICAL CHARACTERISTICS 
MAXIMUM RATINGS 

Voo With Respect to Vss (Ground) =15 to -0.3V 
Max. Voltage to Any Input With =15 to -0.3V 
Respect to Vss 

Vqq = ID ma Nominal Vqc = 35 ma Nominal 

OPERATING CHARACTERISTICS (DC) 

TA = 0°C to 70°C, Voo = + 12V ± .6V. Vss = OV. Vcc = + 5V ± .25V 



Operating Temperature 
Storage Temperature 



0°Cto70°C 
-55°C to +125°C 



SYMBOL 


CHARACTERISTIC 


MIN. 


MAX. 


UNITS 


CONDITIONS 


k 


Input Leakage 




10 


ma 


Vm = Vdo 


Iol 


Output Leakage 




10 


ma 


VOWT = VOO 


Vim 


Input High Voltage 


26 




V 




VlL 


Input Low Voltage 




0.8 


V 




v<* 


Output High Voltage 


2.8 




V 


Io = -100mA 


Vol 


Output Low Voltage 




0.45 


V 


lo = 1.6 mA 


Pd 


Power Dissipation 




0.5 


W 
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TIMING CHARACTERISTICS 

T» • 0°C to 70°C. Voo - + 12V ± .6V. Vss - OV, Vcc *+SV ± 25V 

READ ENABLE TIMING 



SYMBOL 


CHARACTERISTIC 


MIN. 


TYP. 


MAX. 


UNITS 


CONDITIONS 


TSET 


Setup ADOR & CS to Pfl= 


50 






nsec 




THLD 


Hold AODR & CS from RE 


10 






nsec 




TRE 


RE Pulse Width 


400 






nsec 


Ct = 50pf 


TDRR 


DRQ Reset from RE 




400 


500 


nsec 




TIRR 


INTRQ Reset from RE 




500 


3000 


nsec 


See Note 5 


TDACC 


Data Access from RE 






350 


nsec 


G. = 50pf 


TDOH 


Data Hold From RE 


50 




150 


nsec 


Ct = 50pf 









' 


|-»— 'wm 




i 






1 






.. ,«, ^ 




— «*| 'SERVICE 




... 1 







-• — '■» — •> 


~i 
















T 8fT 


T DACC (-•- 




f °* * 1 


■DAU 


1 -y 1 








i E3 
SCRVIi 


-^■FOOlj * 

MAY K PERMANENT!. V T«0 LOW If Of S«C0 
IE OOUM.ES WMtN CtOCK «MM» 

E (WORST CASE) 
Si»S 



READ ENABLE TIMING 
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WRITE ENABLE TIMING 



SYMBOL 


CHARACTERISTIC 


MIN. 


TYP. 


MAX. 


UNITS 


CONDfTIONS 


TSET 

THLD 

TWE 

TDRR 

TIRR 

TDS 

TDH 


Setup ADDR & CS to WE 
Hold ADDR ft CS from Wl 

WE Pube Width 

DRQ Reset from WE 
INTRQ Reset from WE 
Data Setup to WE* 
Data Hold from WE 


50 

10 

350 

250 
70 


400 
500 


500 
3000 


nsec 
nsec 
nsec 
nsec 
nsec 
nsec 
nsec 


See Note 5 



INPUT DATA TIMING: 



SYMBOL 


CHARACTERISTIC 


MIN. 


TYP. 


MAX. 


UNITS 


CONDITIONS 


Tpw 

tbc 

Tc 

Txi 

TX2 


Raw Read Pulse Width 


100 

40 
40 


200 
1500 
1500 




nsec 
nsec 
nsec 
nsec 
nsec 


See Note 1 
1800 ns @ 70°C 
1800ns@70°C 
See Note 1 


Raw Read Cycle Time 
RCLK Cycle Time 


RCLK hold to Raw Read 


Raw Read hold to RCLK 



_r 



H h 



o 
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I SERVICE IWOAST C»SCi 



NOTE ICSMtvaCKHMMCNTlvTIfDiawrilCsnCO 

i m«N vmrTMO wn into sectoh tnack an data 

WOSTER ustn CWMOT HEM) TMS WOSTCII uxra. 

AT LUST 4 ,SEC M im AFTEK THE RBMG ED« OF «W 

IMCNVrtOTMGMTO THE COMMAND NEOISTEri STATUS 

IS NOT VAI.O UNTH SOME » .SEC M m. 14 .SEC H HTH 

UTEfl THESE TIMES ARE DOUHEO HHEN CUC 1 MH* 

-TME 0OUBLES WHEN CLOCK IMHt 












NOMINAL 


DISKETTE 


MOOE 


DDEN 


cue 


T. 


T» 


T. 


8" 
8" 
5" 
5" 


MFM 
FM 

MFM 
FM 



1 

1 


2 MHz 
2 MHz 
1MHz 
1 MHz 


2"« 
2«* 
4«s 


IK 

2m» 
4u» 


2hM 
8«s 



INPUT DATA TIMING 



WRITE ENABLE TIMING 



350 



WRITE DATA TIMING: (ALL TIMES DOUBLE WHEN CLK = 1 MHz) 



SYMBOL 


CHARACTERISTICS 


MIN. 


TYP. 


MAX. 


UNITS 


CONDITIONS 


Twp 


Write Data Pulse Width 


450 


500 


550 


nsec 


FM 






150 


200 


250 


nsec 


MFM 


Twg 


Write Gate to Write Data 




2 

1 




fisec 
Msec 


FM 
MFM 


Tbc 


Write data cycle Time 




2.3, or 4 




ftsec 


± CLK Error 


Ts 


Early (Late) to Write Data 


125 






nsec 


MFM 


Th 


Early (Late) From 
Write Data 


125 






nsec 


MFM 


Twf 


Write Gate off from WD 




2 

1 




fisec 
jisec 


FM 
MFM 


Twdl 


WD Valid to Clk 


100 
50 






nsec 
nsec 


CLK=1 MHZ 
CLK=2 MHZ 


Twd2 


WD Valid after CLK 


100 
30 






nsec 
nsec 


CLK=1 MHZ 
CLK=2 MHZ 



~L 



K 



H 



1_ 



V/////A V/////A 

T««dl J U T«rd2 



CLK 
(2MHZ) 



~L 



iSi — ,2s — H 



V/////A V/////A 



— »«| I \* — 



WRITE DATAKXOCK ROATM3NSHIP 
(DOEN-0) 



WRITE DATA TIMING 
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MISCELLANEOUS TIMING: 

















SYMBOL 


CHARACTERISTIC 


MIN. 


TYP. 


MAX. 


UNITS 


CONDITIONS 


TCDi 


Clock Duty (low) 


230 


250 


20000 


nsec 




TCD* 


Clock Duty (high) 


200 


250 


20000 


nsec 




TSTP 


Step Pulse Output 


2or4 






usee 


See Note 5 


TDIR 


Dir Setup to Step 




12 




psec 


± CLK ERROR 


TMR 


Master Reset Pulse Width 


50 






/isec 




TIP 


Index Pulse Width 


10 






Msec 


See Note 5 


TWF 


Write Fault Pulse Width 


10 






fisec 





H— H 



5 J_ 



K-- H 



h— H 




__rL_rL„ TL 



MISCELLANEOUS TIMING 



NOTES: 

1. Pulse width on RAW READ (Pin 27) is normally 
100-300 ns. However, pulse may be any width if 
pulse is entirely within window. If pulse occurs in both 
windows, then pulse width must be less than 300 ns 
for MFM at CLK = 2 MHz and 600 ns for FM at 2 
MHz. Times double for 1 MHz. 

2. A PPL Data Separator is recommended for 8" MFM. 



3. tbc should be 2 ^s, nominal in MFM and 4 fis nominal 
in FM. Times double when CLK = 1 MHz. 

4 . RCLK may be high or low during RAW READ (Polarity 
is unimportant). 

5. Times double when clock = 1 MHz. 
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FD179X Application Notes 



INTRODUCTION 

Over the past several years, the Floppy Disk Drive has 
become the most popular on-line storage device for 
mini and microcomputer systems. Its fast access time, 
reliability and low cost-per-bit ratio enables the Floppy 
Disk Drive to be the solution in mass storage for mi- 
croprocessor systems. The drive interface to the Host 
system is standardized, allowing the OEM to substitute 
one drive for another with minimum hardware/ software 
modifications. 



Since Floppy Disk Data is stored and retrieved as a 
self-clocking serial data stream, some means of sep- 
arating the clock from the data and assembling this 
data in parallel form must be accomplished. Data is 
stored on individual Tracks of the media, requiring con- 
trol of a stepper motor to move the Read/Write head 
to a predetermined Track. Byte sychronization must 
also be accomplished to insure that the parallel data 
is properly assembled. After all the design considera- 
tions are met, the final controller can consist of 40 or 
more TTL packages. 

To alleviate the burden of Floppy Disk Controller de- 
sign. Western Digital has developed a Family of LSI 
Floppy Disk controller devices. Through its own set of 
macro commands, the FD179X Controller Family will 
perform all the functions necessary to read and write 
data to the drive. Both the 8" standard and 5%" mini- 
floppy are supported with single or double density re- 
cording techniques. The FD179X is compatible with 
the IBM 3740 (FM) data format, or the System 34 
(MFM) standards. Provisions for non-standard formats 
and variable sector lengths have been included to pro- 
vide more storage capability per track. Requiring stan- 
dard +5, +12 power supplies the FD179X is available 
in a standard 40 pin dual-in-line package. 

The FD179X Family consists of 6 devices. The 
differences between these devices is summarized in 
Figure 1. The 1792 and 1794 are "single density only" 
devices, with the Double Density Enable pin (DDEN) 
left open by the user. Both True and inverted Data bus 
devices are available. Since the 179X can only drive 
one TTL Load, a true data bus system may use the 
1791 with external inverting buffers to arrive at a true 
bus scheme. The 1795 and 1797 are identical to the 
1791 and 1793, except a side select output has been 
added that is controlled through the Command Register. 



a 
u 

SYSTEM DESIGN | 

The first consideration in Floppy Disk Design is to de- § 
termine which type of drive to use. The choice ranges 
from single-density single sided mini-floppy to the 8" 
double-density double-sided drive. Figure 2 illustrates 
the various drive and data capacities associated with 
each type. Although the 8" double-density drive offers 
twice as much storage, a more complex data separator 
and the addition of Write Precompensation circuits are 
mandatory for reliable data transfers. Whether to go 
with 8" double-density or not is dependent upon PC 
board space and the additional circuitry needed to ac- 
curately recover data with extreme bit shifts. The byte 
transfer time defines the nominal time required to 
transfer one byte of data from the drive. If the CPU 
used cannot service a byte in this time, then a DMA 
scheme will probably be required. The 179X also needs 
a few microseconds for overhead, which is subtracted 
from the transfer time. Figure 3 shows the actual ser- 
vice times that the CPU must provide on a byte-by-byte 
basis. If these times are not met, bytes of data will be 
lost during a read or write operation. For each byte 
transferred, the 179X generates a DRQ (Data Re- 
quest) signal on Pin 38. A bit is provided in the status 
register which is also set upon receipt of a byte from 
the Disk. The user has the option of reading the status 
register through program control or using the DRQ Line 
with DMA or interrupt schemes. When the data register 
is read, both the status register DRQ bit and the DRQ 
Line are automatically reset. The next fuH byte will 
again set the DRQ and the process continues until the 
sector(s) are read. The Write operation works exactly 
the same way, except a WRITE to the Data Register 
causes a reset of both DRQ's. 



RECORDING FORMATS 

The FD179X accepts data from the disk in a Fre- 
quency-Modulated (FM) or Modified-Frequency-Mod- 
ulated (MFM) Format. Shown in Figures 4A and 4B are 
both these Formats when writing a Hexidecimal byte 
of 'D2'. In the FM mode, the 8 bits of data are broken 
up into "bit cells." Each bit cell begins with a clock 
pulse and the center of the bit cell defines the data. If 
the data bit = 0, no pulse is written; if the data = 1, 
a pulse is written in the center of the cell. For the 8" 
drive, each dock is written 4 microseconds apart. 
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In the MFM mode, clocks are decoded into the data 
stream. The byte is again broken up into bit cells, with 
the data bit written in the center of the bit cell if data 
= 1 . Clocks are only written if both surrounding data 
bits are zero. Figure 4B shows that this occurs only 
once between Bit cell 4 and 5. Using this encoding 
scheme, pulses can occur 2, 3 or 4 microseconds 
apart. The bit cell time is now 2 microseconds; twice 
as much data can be recorded without increasing the 
Frequency rate due to this encoding scheme. 

The 1 79X was designed to be compatible with the IBM 
3740 (FM) and System 34 (MFM) Formats. Although 
most users do not have a need for data exchange with 
IBM mainframes, taking advantage of these well stud- 
ied formats will insure a high degree of system 
performance. The 179X will allow a change in gap 
fields and sector lengths to increase usable storage 
capacity, but variations away from these standards is 
not recommended. Both IBM standards are soft-sector 
format. Because of the wide variation in address marks, 
the 179X can only support soft-sectored media. Hard 
sectored diskettes have continued to lose popularity, 
mainly due to the unavailability of a standard and the 
limitation of sector lengths imposed by the physical 
sector holes in the diskette. 



PROCESSOR INTERFACE 

The Interface of the 179X to the CPU consists of an 
8-bit Bi-directional bus, read/write controls and optional 
interrupt lines. By selecting the device via the CHIP 
SELECT Line, each of the five internal registers can 
be accessed. 



Shown below are the registers and their addresses: 



PIN 3 


PIN 6 


PIN 5 


PIN 4 


PIN 2 


CS 


A, 


Ao 


RE=#" 


WE=*0" 











STATUS REG 


COMMAND 
REG 








1 


TRACK REG 


TRACK REG 





1 





SECTOR REG 


SECTOR REG 





1 


1 


DATA REG 


DATA REG 


1 


X 


X 


H1-Z 


H1-Z 



The Ag, A,, Lines used for register selections can be 
configured at the CPU in a variety of ways. These lines 
may actually tie to CPU address lines, in which case 
the 179X will be memory-mapped and addressed like 
RAM. They may also be used under Program Control 
by tying to a port device such as the 8255, 6820, etc. 
As a diagnostic tool when checking out the CPU in- 
terface, the Track and Sector registers should respond 
like "RAM" when the 179X is idle (Busy = INTRQ = 
0). 

Because of internal synchronization cycles, certain 
time delays must be introduced when operating under 
Programmed I/O. The worst case delays are: 



OPERATION 

WRITE TO 
COMMAND REG 


NEXT 
OPERATION 


DELAY REQ'D 


READ STATUS 
REGISTER 


MFM = 14/iS* 
FM = 28ms. 


WRITE TO 
ANY REGISTER 


READ FROM A 
DIFFERENT REG 


NO DELAY 



'NOTE: Times Double when CLK = 1MHz (5'A" drive) 



Other CPU interface lines are CLK, MR and DDEN. 
The CLK line should be 2MHz (8" drive) or 1MHz (5y-»" 
drive) with a 50% duty cycle. Accuracy should be ±1% 
(crystal source) since all internal timing, including step- 
ping rates, are based upon this clock. 
The MR or Master Reset Line should be strobed a 
minimum of 50 microseconds upon each power-on 
condition. This line clears and initializes all internal reg- 
isters and issues a restore command (Hex '03') on the 
rising edge. A quicker stepping rate can be written to 
the command register after a MR, in which case the 
remaining steps will occur at the faster programmed 
rate. The 1 79X will issue a maximu m of 25 5 stepping 
pulses in an attempt to expect the TROO line to go 
active l ow. This line should be connected to the drive's 
TROO sensor. 

The DDEN line causes selection of either singl e den- 
sity (DDEN = 1) or double density operation. DDEN 
should not be switched during a read or write operation. 



Each time a command is issued to the 1 79X, the Busy 
bit is set and the INTRQ (Interrupt Request) Line is 
reset. The user has the option of checking the busy bit 
or use the INTRQ Line to denote command comple- 
tion. The Busy bit will be reset whenever the 179X is 
idle and awaiting a new command. The INTRO Line, ■ 
once set, can only be reset by a READ of the status 
register or issuing a new command. The MR (Master 
Reset) Line does not affect INTRQ. 
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FLOPPY DISK INTERFACE 

The Floppy Disk Interface can be divided into three 
sections: Motor Control, Write Signals and Read Sig- 
nals. All of these lines are capable of driving one TTL 
load and not compatible for direct connection to the 
drive. Most drives require an open-collector TTL inter- 
face with high current drive capability. This must be 
done on all outputs from the 179X. Inputs to the 179X 
may be buffered or tied to the Drives outputs, providing 
the appropriate resistor termination networks are used. 
Undershoot should not exceed -0.3 volts, while integ- 
rity of V IH and V OH levels should be kept within spec. 

MOTOR CONTROL 

Motor Control is accomplished by the STEP and DIRC 
Lines. The STEP Line issues stepping pulses with a 
period defined by the rate field in all Type I commands. 
The DIRC Line defines the direction of steps (DIRC = 
1 STEP IN/DIRC = STEP OUT). 
Other Control Lines include the IP or Index Pulse. This 
Line is tied to the drives' Index L.E.D. sensor and 
makes an ac tive tra nsition for each revolution of the 
diskette. The TROO Line is another LE.D. sensor that 
informs the 179X that the stepper motor is at its fur- 
thest position, over Track 00. The READY Line can be 
used for a number of functions, such as sensing "door 
open", Drive motor on, etc. Most drives provide a pro- 
grammable READY Signal selected by option jumpers 
on the drive. The 1 79X will look at the ready signal prior 
to executing READ/WRITE commands. READY is nor 
inspected during any Type I commands. All Type I 
commands will execute regardless of the Logic Level 
on this Line. 

WRITE SIGNALS 

Writing of data is accomplished by the use of the WD, 
WG, WF, TG43, EARLY and LATE Lines. The WG or 
Write Gate Line is used to enable write current at the 
drive's R/W head. It is made active prior to writing data 
on the disk? The WF or WRITE FAULT Line is used to 
inform the 179X of a failure in drive electronics. This 
signal is multiplexed with the VFOE Line and must be 
logically separated if required. Figure 5 illustrates three 
methods of demultiplexing. 

The TG43 or "TRACK GREATER than 43" Line is 
used to decrease the Write current on the inner tracks, 
where bit densities are the highest. If not required on 
the drive, TG43 may be left open. 

WRITE PRECOMPENSATION 

The 179X provides three signals for double density 
Write Precompensation use. These signals are WRITE 
DATA, EARLY and LATE. When using single density 
drives (eighter 8" or 5VV), Write Precompensation is 
not necessary and the WRITE DATA line is generally 
TTL Buffered and sent directly to the drive. In this 
mode, EARLY and LATE are left open. 
For double density use, Write Precompensation is a 
function of the drive. Some manufacturers recommend 
Precompensating the 5 1 /i" drive, while others do not. 
With the 8" drive, Precompensation may be specified 
from TRACK 43 on, or in most cases, all TRACKS. If 
the recommended Precompensation is not specified. 



check with the manufacturer for the proper configura- 
tion required. 

The amount of Precompensation time also varies. A 
typical value will usually be specified from 100-300ns. 
Regardless of the parameters used, Write Precom- 
pensation must be done external to the 179X. When 
DDEN is tied low, EARLY or LATE will be activated at 
least 125ns. before and after the Write Data pulse. An 
Algorithm internal the 179X decides whether to raise 
EARLY or LATE, depending upon the previous bit pat- 
tern sent. As an example, suppose the recommended 
Precomp value has been specified at 150ns. The fol- 
lowing action should be taken: 



EARLY LATE 



ACTION TAKEN 



delay WD by 150ns (nominal) 
1 delay WD by 300ns (2X value) 
1 do not delay WD 

There are two methods of performing Write 
Precompensation: 

1) External Delay elements 

2) Digitally 

Shown in Figure 6 is a Precomp circuit using the West- 
ern Digital 2143 clock generator as the delay element. 
The WD pulse from the 179X creates a strobe to the 
2143, causing subsequent output pulses on the4fl,>02 
and 03 signals. The 5K Precomp adjust sets the de- 
sired Precomp value. Depending upon the condition of 
EARLY and LATE, 01 will be used for EARLY, 02 for 
nominal (EARLY = LATE = 0), and 03 for LATE. The 
use of "one-shots" or delay line in a Write Precom- 
pensation scheme offers the user the ability to vary the 
Precomp value. The 04 output resets the 74LS175 
Latch in anticipation of the next WD pulse. Figure 7 
shows the WD-EARLY/LATE relationship, while Figure 
8 shows the timing of this write Precomp scheme. 
Another method of Precomp is to perform the function 
digitally. Figure 9 illustrates a relationship between the 
WD pulse and the CLK pin, allowing a digital Precomp 
scheme. Figure 10 shows such a scheme with a pre- 
set Write Precompensation value of 250ns. The syn- 
chronous counter is used to generate 2MHz and 4MHz 
clock signals. The 2MHz clock is sent to the CLK input 
of the 179X and the 4MHz is used by the 4-bit shift 
register. When a WD pulse is not present, the 4MHz 
clock is shifting "ones" through the shift register and 
maintaining Q D at a zero level. When a WD pulse is 
present, a zero is loaded at either A, B, or C depending 
upon the states of LATE, EN PRECOMP and EARLY. 
The zero is then shifted by the 4MHz clock until it 
reaches the Q output. The number of shift operations 
determines whether the WRITE DATA pulse is written 
early, nominal or late. If both FM and MFM operations 
is a system requirement, the output of this circuit should 
be disabled and the WD pulse should be sent directly 
to the drive. 
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DATA SEPARATION 

The 179X has two inputs (RAW READ & RCLK) and 
one output (VFOE) for use by an external data sepa- 
rator. The RAW READ input must present clock and 
data pulses to the 179X, while the RCLK input provides 
a "window" or strobe signal to clock each RAW READ 
pulse into the device. An ideal Data Separator would 
have the leading edge of the RAW READ pulse occur 
in the exact center of the RCLK strobe. 
Motor Speed Variation, Bit shifts and read amplifier 
recovery circuits all cause the RAW READ pulses to 
drift away from their nominal positions. As this occurs, 
the RAW READ pulses will shift left or right with re- 
spect to RCLK. Eventually, a pulse will make its tran- 
sition outside of its RCLK window, causing either a 
CRC error or a Record-not-Found error at the 179X. 
A Phase-Lock-Loop circuit is one method of achieving 
synchronization between the RCLK and RAW READ 
signals. As RAW READ pulses are fed to the PLL, 
minor adjustments of the free-running RCLK frequency 
can be made. If pulses are occurring too far apart, the 
RCLK frequency is decreased to keep synchroniza- 
tion. If pulses begin to occur closer together, RCLK is 
increased until this new higher frequency is achieved. 
In normal read operations, RCLK will be constantly 
adjusted in an attempt to match the incoming RAW 
READ frequency. 

Another method of Data Separation is the Counter- 
Separator technique. The RCLK signal is again free- 
running at a nominal rate, until a RAW READ pulse 
occurs. The Separator then denotes the position of the 
pulse with respect to RCLK (by the counter value), and 
counts down to increase or decrease the current RCLK 
window. The next RCLK window will occur at a nominal 
rate and will continue to run at this frequency until an- 
other RAW READ pulse adjusts RCLK, but only the 
present window is adjusted. 
Both PPL and Counter/Separator are acceptable 
methods of Data Separation. The PPL has the highest 
reliability because of its "tracking" capability and is rec- 
ommended for 8" double density designs. 

As a final note, the term "Data Separator" may be 
misleading, since the physical separation of clock and 
data bits are not actually performed. This term is used 
throughout the industry, and can better be described 
as a "Data Recovery Circuit" rather than a Data 
Separator. 

The VFOE signal is an output from the 179X that sig- 
nifies the head has been loaded and valid data pulses 
are appearing on the RAW READ line. It can be used 
to enable the Data Separator and to insure clean RCLK 
transitions to the 179X. Since some drives will output 
random pulses when the head is disengaged, VFOE 
can prevent an erratic RCLK signal during this time. If 
the Data Separator requires synchronization during a 
known pattern of one's or zero's, then RG (READ 
GATE) can be used. The RG signal will go active when 
the 1 79X is currently over a field of zeros or ones. RG 
is not available on the 1795/1797 devices, since this 
signal was replaced with the SSO (Side Select Output) 
Line. 



Shown in Figure 1 1 is a 2 1 /2 IC Counter/Separator. The 
74LS193 free runs at a frequency determined by the 
CRYCLK input. When a RAW READ pulse occurs, the 
counter is loaded with a starting count of '5'. When the 
RAW READ Line returns to a Logic 1, the counter 
counts down to zero and again free runs. The 74LS74 
insures a 50% duty cycle to the 179X and performs a 
divide-by-two of the Q D output. 
Figure 12 illustrates another Counter/Separator utiliz- 
ing a PROM as the count generator. Depending upon 
the RAW READ phase relationship to RCLK, the PROM 
is addressed and its data output is used as the counter 
value. A 16MHz clock is required for 8" double density, 
while an 8MHz clock can be used for single density. 
Figure 13 shows a Phase-Lock-Loop data recovery 
circuit. The phase detector (U2, Figure 2) compares 
the phase of the SHAPED DATA pulse to the phase 
of VFO CLK ~ 2. If VFO CLK 4- 2 is lagging the 
SHAPED DATA pulse an output pulse on #9, U2 is 
generated. The filter/amplifier converts this pulse into 
a DC signal which increases the frequency of the VCO. 
If, correspondingly, CLK •?- 2 is leading the SHAPED 
DATA pulse, an output pulse on #5, U2 is generated. 
This pulse is converted into a DC signal which de- 
creases the frequency of the VCO. These two actions 
cause the VCO to track the frequency of the incoming 
READ DATA pulses. This correction process to keep 
the two signals in phase is constantly occurring because 
of spindle speed variation and circuit parameter 
variations. 

The operating specifications for this circuit are as 
follows: 



Free Running Frequency 
Capture Range 
Lock Up Time 


2MHz 
± 15% 

50 microsec. "1111" or 
"0000" Pattern 
100 Microsec "1010" Pat- 
tern 



The RAW READ pulses are generated from the falling 
edge of the SHAPED DATA pulses. The pulses are 
also reshaped to meet the 179X requirements. VFO 
CLK + 2 OR 4 is divided by 2 once again to obtain 
VFO CLK OUT whose frequency is that required by the 
179X RCLK input. RCLK must be controlled by VFOE 
so VFOE is sampled on each rising edge of VFO CLK 
OUT. When VFOE goes active EN RCLK goes active 
in synchronization with VFO CLK OUT preventing any 
glitches on the RCLK output. When VFOE goes inac- 
tive EN RCLK goes inactive in synchronization with 
VFO CLK OUT, again preventing any glitches on the 
RCLK output. 

Figure 14 illustrates a PPL data recovery circuit using 
the Western Digital 1691 Floppy Support device. Both 
data recovery and Write Precomp Logic is contained 
within the 1691, allowing low chip count and PLL re- 
liability. The 74S124 supplies the free-running VCO 
output. The PUMP UP and PUMP DOWN signals from 
the 1691 are used to control the 74S124's frequency. 
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COMMAND USAGE 

Whenever a command is successfully or unsuccess- 
fully completed, the busy bit of the status register is 
reset and the INTRO line is forced high. Command ter- 
mination may be detected either way. The INTRQ can 
be tied to the host processor's interrupt with an appro- 
priate service routine to terminate commands. The 
busy bit may be monitored with a user program and 
will achieve the same results through software. Per- 
forming both an INTRQ and a busy bit check is not 
recommended because a read of the status register to 
determine the condition of the busy bit will reset the 
INTRQ line. This can cause an INTRQ from not 
occurring. 

RESTORE COMMAND 

On some disk drives, it is possible to position the R/W 
head outward past Track 00 and prevent the TROO 
line from going low unless a STEP IN is first performed. 
If this condition exists in the drive used, the RESTORE 
command will never detect a TROO. Issuing several 
STEP IN pulses before a RESTORE command will 
remedy this situation. The RESTORE and all other 
Type I commands will execute even though the READY 
bit indicates the drive is not ready (NOT READY =1). 

READ TRACK COMMAND 

The READ TRACK command can be used to manually 
inspect data on a hard copy printout. Gaps, address 
marks and all data are brought in to the data register 
during this command. The READ TRACK command 
may be used to inspect diskettes for valid formatting 
and data fields as well as address marks. Since the 
179X does not synchronize clock and data until the In- 
dex Address Mark is detected, data previous to this ID 
mark will not be valid. READ GATE (RG) is not ac- 
tuated during this command. 

READ ADDRESS COMMAND 

In systems that use either multiple drives or sides, the 
read address command can be used to tell the host 
processor which drive or side is selected. The current 
position of the R/W head is also denoted in the six 
bytes of data that are sent to the computer. 



TRACK SIDE 


SECTOR 


CRS 
LENGTH 


CRC 

1 


CRC 
2 



The READ ADDRESS command as well as all other 
Type II and Type III commands will not execute if the 
READY line is inactive (READY = 0). Instead, an in- 
terrupt will be generated and the NOT READY status 
bit will be set to a 1. 



FORCED INTERRUPT COMMAND 

The Forced Interrupt command is generally used to 
terminate a multiple sector command or to insure Type 
I status in the status register. The lower four bits of the 
command determine the conditional interrupt as follows. 



1 = NOT-READY TO READY TRANSITION 

1, = READY TO NOT-READY TRANSITION 

1 2 = EVERY INDEX PULSE 

1, = IMMEDIATE INTERRUPT 



Regardless of the conditional interrupt set, any com- 
mand that is currently being executed when the Forced 
Interrupt command is loaded will immediately be ter- 
minated and the busy bit will be reset indicating an idle 
condition. 

Then, when the condition for interrupt is met, the INTRQ 
line will go high signifying that the condition specified 
has occurred. 

The conditional interrupt is enabled when the corre- 
sponding bit positions of the command (l 3 -l ) are set 
to a 1 . If l 3 - 1 are all set to zero, no interrupt will occur, 
but any command presently under execution will be 
immediately terminated upon receipt of the Force In- 
terrupt command (HEX DO). 
As usual, to clear the intenupt a read of the status reg- 
ister or a write to the command register is required. 
The exception is when using the immediate interrupt 
condition (l 3 = 1). If this command is loaded into the 
command register, an interrupt will be immediately 
generated and the current command terminated. 
Reading the status or writing to the command register 
will not automatically clear the interrupt; another forced 
interrupt command with l 3 -l„ = must be loaded into 
the command register in order to reset the INTRQ from 
this condition. 

More than one condition may be set at a time. If for 
example, the READY TO NOT-READY condition (I, = 
1) and the Every Index Pulse (l 2 = 1) are both set, the 
resultant command would be HEX "DA". The "OR" 
function is performed so that either a READY TO NOT- 
READY or the next Index Pulse will cause an interrupt 
condition. 

DATA RECOVERY 

Occasionally, the R/W head of the disk drive may get 
"off track", and dust or dirt may get trapped on the 
media. Both of these conditions will cause a RECORD 
NOT FOUND and/or a CRC error to occur. This "soft 
error" can usually be recovered by the following 
procedure: 

1 . Issue the command again 

2. Unload and load the head and repeat step 

3. Issue a restore, seek the track, and repeat step 1 




If RNF or CRC errors are still occurring after trying 
these methods, a "hard error" may exist. This is usu- 
ally caused by improper disk handling, exposure to 
high magnetic fields, etc. and generally results in de- 
stroying portions or tracks of the diskette. 
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FIGURE 1 DEVICE CHARACTERISTICS 



DEVICE 


SNGL DENSITY 


DBLE DENSITY 


INVERTED BUS 


TRUE BUS 


DOUBLE-SIDED 


1791 


X 


X 


X 






1792 


X 




X 






1793 


X 


X 




X 




1794 


X 






X 




1795 


X 


X 


X 




X 


1797 


X 


X 




X 


X 



FIGURE 2 STORAGE CAPACITIES 



SIZE 


DENSITY 


SIDES 


UNFORMATTED 
CAPACITY (NOMINAL) 


BYTE 

TRANSFER 

TIME 


FORMATTED 
CAPACITY 


PER TRACK 


PER DISK 


PER TRACK 


PER DISK 


SVS 

5V4" 

5V4" 

5V4" 

8" 

8" 

8" 

8" 


SINGLE 

DOUBLE 

SINGLE 

DOUBLE 

SINGLE 

DOUBLE 

SINGLE 

DOUBLE 


1 
1 
2 
2 
1 
1 
2 
2 


3125 
6250 
3125 
6250 
5208 

10.416 
5208 

10,416 


109,375* 
218,750 
218,750 
437,500 
401,016 
802,032 
802.032 
1.604,064 


64mS 
32ms 
64/iS 
32/iS 
32/tS 
16mS 
32/us 
16mS 


2304** 

4608*** 

2304 

4608 

3328 

6656 

3328 

6656 


80,640 
161,280 
161,280 
322,560 
256.256 
512,512 
512,512 
1,025,024 



'Based on 35 Tracks/Side 
"Based on 18 Sectors/Track (128 byte/sec) 
'"Based on 18 Sectors/Track (256 bytes/sec) 
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11.5 Appendex E - Z80A CPU 



Z8400 

Z80CPU Central 
Processing Unit 




Zilog 



Product 
Specification 



March 1981 



FocrturM ■ The instruction set contains 158 instructions. 

The 78 instructions of the 8080A are 
included as a subset; 8080A software com- 
patibility is maintained. 

■ Six MHz, 4 MHz and 2.5 MHz clocks for the 
Z80B, Z80A, and Z80 CPU result in rapid 
instruction execution with consequent high 
data throughput. 

■ The extensive instruction set includes string, 
bit, byte, and word operations. Block 
searches and block transfers together with 
indexed and relative addressing result in 
the most powerful data handling capabilities 
in the microcomputer industry. 

■ The Z80 microprocessors and associated 
family of peripheral controllers are linked 
by a vectored interrupt system. This system 



may be daisy-chained to allow implemen- 
tation of a priority interrupt scheme. Little, 
if any, additional logic is required for 
daisy-chaining. 

Duplicate sets of both general-purpose 
and flag registers are provided, easing 
the design and operation of system soft- 
ware through single-context switching, 
background-foreground programming, and 
single-level interrupt processing. In addi- 
tion, two 16-bit index registers facilitate 
program processing of tables and arrays. 

There are three modes of high speed inter- 
rupt processing: 8080 compatible, non-Z80 
peripheral device, and Z80 Family 
peripheral with or without daisy chain. 

On-chip dynamic memory refresh counter. 
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a 





, , 




M1 


An 




„ > 












Ai 




— ► 










MREQ 

iono 


As 
A» 


















SYSTEM 












CONTROL 






RD 


A4 




T"" 










WR 


As 

A. 


























RFSH 


At 


















BUS 










A. 








' ■* — 




HALT 


A9 

Aio 


























WAIT 

z so cpu 


An 
An 


















CONTROL 














— *■ 


INT 


Aia 














NMI 


Al4 

Ais 


» 




















L 




RESET 


Do 






















CPU 






SUSREQ 
BUSACK 


Dl 








BUS < 






CONTROL 
























BUS 








CLK 
+ 5V 


0, 

D» 


■»— 


— ♦• 






"■ 


QND 


l>7 









A„C 
A12 C 
A« £ 
Am fj 

A«C 
CLK £ 

0,C 
CC 

*C 

.SVC 

*C 

^c 

INT £ 

am fj 

HALT rj 
SSK5 £ 
iORQ £ 



«0 3 A 10 

3» ]| A, 

3» ] A, 

37 J A 7 

M 3 *• 

35 3 As 

34 3 A, 

33 3 A 3 

32 3 A 2 

31 3 A, 

30 3 *» 

M 3 ° ND 

28 3 RFSB 

27 3 Hi 

26 3 RESET 

25 3 BUSREO 

24 3 WA TT 

23 3 BUSACK 

22 3*S 

21 3 "B 



Figure 1. Pin Functions 



Figure 2. Pin Assignments 
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General The Z80, Z80A, and Z80B CPUs are third- 

Description generation single- chip microprocessors with 
exceptional computational power. They offer 
higher system throughput and more efficient 
memory utilization than comparable second- 
and third-generation microprocessors. The 
internal registers contain 208 bits of read/write 
memory that are accessible to the programmer. 
These registers include two sets of six general- 
purpose registers which may be used 
individually as either 8-bit registers or as 
16-bit register pairs. In addition, there are two 
sets of accumulator and flag registers. A group 
of "Exchange" instructions makes either set of 
main or alternate registers accessible to the 
programmer. The alternate set allows operation 
in foreground-background mode or it may 



be reserved for very fast interrupt response. 
The Z80 also contains a Stack Pointer, Pro- 
gram Counter, two index registers, a Refresh 
register (counter), and an Interrupt register. 
The CPU is easy to incorporate into a system 
since it requires only a single + 5 V power 
source, all output signals are fully decoded 
and timed to control standard memory or 
peripheral circuits, and is supported by an 
extensive family of peripheral controllers. The 
internal block diagram (Figure 3) shows the 
primary functions of the Z80 processors. 
Subsequent text provides more detail on the 
Z80 I/O controller family, registers, instruction 
set, interrupts and daisy chaining, and CPU 
timing. 




« SYSTEMS S CPU 
AND CPU CONTROL 
CONTROL INPUTS 
OUTPUTS 



16-BIT 
ADDRESS BUS 



Figure 3. Z80 CPU Block Diagram 
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Z80 Micro- The Zilog Z80 microprocessor is the central 

processor element of a comprehensive microprocessor 

Family product family. This family works together in 

most applications with minimum requirements 
for additional logic, facilitating the design of 
efficient and cost-effective microcomputer- 
based systems. 

Zilog has designed five components to pro- 
vide extensive support for the Z80 micro- 
processor. These are: 

■ The PIO (Parallel Input/Output) operates in 
both data-byte I/O transfer mode (with 
handshaking) and in bit mode (without 
handshaking). The PIO may be config- 
ured to interface with standard parallel 
peripheral devices such as printers, 

tape punches, and keyboards. 

■ The CTC (Counter/Timer Circuit) features 
four programmable 8-bit counter/timers. 



each of which has an 8-bit prescaler. Each 
of the four channels may be configured to 
operate in either counter or timer mode. 

t The DMA (Direct Memory Access) con- 
troller provides dual port data transfer 
operations and the ability to terminate data 
transfer as a result of a pattern match. 

The SIO (Serial Input/Output) controller 
offers two channels. It is capable of 
operating in a variety of programmable 
modes for both synchronous and asyn- 
chronous communication, including 
Bi-Synch and SDLC. 

The DART (Dual Asynchronous Receiver/ 
Transmitter) device provides low cost 
asynchronous serial communication. It has 
two channels and a full modem control 
interface. 



Z80 CPU Figure 4 shows three groups of registers 

Registers within the Z80 CPU. The first group consists of 

duplicate sets of 8-bit registers: a principal set 
and an alternate set (designated by ' [prime], 
e.g., A')- Both sets consist of the Accumula- 
tor Register, the Flag Register, and six 
general-purpose registers. Transfer of data 
between these duplicate sets of registers is 
accomplished by use of "Exchange" instruc- 
tions. The result is faster response to interrupts 
and easy, efficient implementation of such ver- 
satile programming techniques as background- 



foreground data processing. The second set of 
registers consists of six registers with assigned 
functions. These are the I (Interrupt Register), 
the R (Refresh Register), the IX and IY (Index 
Registers), the SP (Stack Pointer), and the PC 
(Program Counter). The third group consists of 
two interrupt status flip-flops, plus an addi- 
tional pair of flip-flops which assists in identi- 
fying the interrupt mode at any particular 
time. Table 1 provides further information on 
these registers. 



MAIN IWOISTER SIT 



ALTERNATE MOIST!* MT 



A ACCUMULATOR 


F FLAG REGISTER 


A 1 ACCUMULATOR 


F- FLAG REGISTER 


B GENERAL PURPOSE 


C GENERAL PURPOSE 


B' GENERAL PURPOSE 


C GENERAL PURPOSE 


D GENERAL PURPOSE 


E GENERAL PURPOSE 


0' GENERAL PURPOSE 


r GENERAL PURPOSE 


H GENERAL PURPOSE 


L GENERAL PURPOSE 


H' GENERAL PURPOSE 


L' GENERAL PURPOSE 



INTERRUPT FLIP-FLOPS STATUS 



IX INDEX REGISTER 



IY INDEX REGISTER 



SP STACK POINTER 



PC PROGRAM COUNTER 



I INTERRUPT VECTOR 



R MEMORY REFRESH 



4: 





IFF1 








IFF2 1 






1* 


- 

1 « 


INTERRUPTS DISABLED STORES IFF1 -, 
INTERRUPTS ENABLED DURING HHi T 
SERVICE J 
INTERRUPT MODE FLIP-FLOPS 




IMF, 


IMF b 








D 

1 
1 



1 

1 


NTERRUPT MODE 
NOT USED 
NTERRUPT MODE 1 
NTERRUPT MODE 2 



Figure 4. CPU Registers 



Z80CPU 
Registers 

(Continued) 



Register 



A, A' 

f, r 

B, B' 

C, C 

D, V 

E, E* 
H, H' 
L. L' 



Accumulator 
Flags 

General Purpose 
General Purpose 
General Purpose 
General Purpose 
General Purpose 
General Purpose 



Sis* (Bits) 

8 
8 
8 
8 
8 
8 
8 
8 



I 




Interrupt Register 


8 


R 




Refresh Register 


8 


IX 




Index Register 


16 


IY 




Index Register 


16 


SP 




Stack Pointer 


16 


PC 




Program Counter 


16 


IFF, 


-IFF 2 


Interrupt Enable 


Flip-Flops 


IMF 


a-IMFb 


Interrupt Mode 


Flip-Flops 



Remarks 

Stores an operand or the results of an operation. 

See Instruction Set. 

Can be used separately or as a 16-bit register with C. 

See B, above. 

Can be used separately or as a 16-bit register with E. 

See D, above. 

Can be used separately or as a 16-bit register with L. 

See H, above. 

Note: The (B.C), (D.E), and (H,L) sets are combined as follows: 
B — High byte C — Low byte 
D — High byte E — Low byte 
H — High byte L — Low byte 

Stores upper eight bits of memory address for vectored interrupt 
processing. 

Provides user-transparent dynamic memory refresh. Automatically 
incremented and placed on the address bus during each 
instruction fetch cycle. 

Used for indexed addressing. 

Same as IX, above. 

Stores addresses or data temporarily. See Push or Pop in instruc- 
tion set. 

Holds address of next instruction. 

Set or reset to indicate interrupt status (see Figure 4). 

Reflect Interrupt mode (see" Figure 4). 



Table 1. Z80 CPU Registers 



Interrupts: Th e C PU a ccept s two interrupt input signals: 

General NMI and INT. The NMI is a non-mask able 

Operation interrupt and has the highest priority. INT is a 
lower priority interrupt since it requires that 
interrupts be e nable d i n so ftware in order to 
operate. Either NMI or INT can be connected 
to multiple peripheral devices in a wired-OR 
configuration. 

The Z80 has a single response mode for 
interrupt service for the non- mask able inter- 
rupt. The maskable interrupt, INT, has three 
programmable response modes available. 
These are: 

■ Mode — compatible with the 8080 micro- 
processor. 



■ Mode 1 — Peripheral Interrupt service, for 
use with non-8080/Z80 systems. 

■ Mode 2 — a vectored interrupt scheme, 
usually daisy-chained, for use with Z80 
Family and compatible peripheral devices. 

Th e C PU s ervices interrupts by sampling the 
NMI and INT signals at the rising edge of the 
last clock of an instruction. Further interrupt 
service processing depends upon the type of 
interrupt that was detected. Details on inter- 
rupt responses are shown in the CPU Timing 
Section. 



Interrupts: Non-Maskable Interrupt (NMI). The non- 
General maskable interrupt cannot be disabled by pro- 
Operation gram control and therefore will be accepted at 
(Continued) at all times by the CPU. NMI is usually 

reserved for servicing only the highest priority 
type interrupts, such as that for orderly shut- 
down after power failur e has been detected. 
After rec ognition of the NMI signal (providing 
BUSREQ is not active), the CPU jumps to 
restart location 0066H. Normally, software 
starting at this address contains the interrupt 
service routine. 

Maskable Interrupt (INT). Regardless of the 
interrupt mode set by the user, the Z80 
response to a maskable interrupt input follows 
a common timing cycle. After the interrupt has 
been detected by the CPU (provided that 
interrupts are enabled and BUSREQ is not 
active) a special interrupt proc essi ng cycle 
begins . This is a special fetch (Ml) cycle in 
which IORQ becomes active rather than 
MREQ, as i n a normal Ml cycle. In addition, 
this sp ecial M l cycle is automatically extended 
by two WAIT states, to allow for the time 
required to acknowledge the interrupt request 
and to place the interrupt vector on the bus. 

Mode Interrupt Operation. This mode is 
compatible with the 8080 microprocessor inter- 
rupt service procedures. The interrupting 
device places an instruction on the data bus, 
which is then acted on six times by the CPU. 
This is normally a Restart Instruction, which 
will initiate an unconditional jump to the 
selected one of eight restart locations in page 
zero of memory. 

Mode 1 Interrupt Operation. Mo de 1 o per- 
ation is very similar to that for the NMI. The 
principal difference is that the Mode 1 inter- 
rupt has a vector address of 0038H only. 

Mode 2 Interrupt Operation. This interrupt 
mode has been designed to utilize most effec- 
tively the capabilities of the Z80 microproc- 
essor and its associated peripheral family. The 
interrupting peripheral device selects the 
starting address of the interrupt service 
routine. It does this by placing an 8-bit 
address vector on the data bus during the 
interrupt acknowledge cycle. The high-order 
byte of the interrupt service routine address is 
supplied by the I (Interrupt) register. This flex- 
ibility in selecting the interrupt service routine 
address allows the peripheral device to use 
several different types of service routines. 
These routines may be located at any available 



location in memory. Since the interrupting 
device supplies the low-order byte of the 
2-byte vector, bit (Arj) must be a zero. 

Interrupt Priority (Daisy Chaining and 
Nested Interrupts). The interrupt priority of 
each peripheral device is determined by its 
physical location within a daisy-chain config- 
uration. Each device in the chain has an inter- 
rupt enable input line (IEI) and an interrupt 
enable output line (IEO), which is fed to the 
next lower priority device. The first device in 
the daisy chain has its IEI input hardwared to 
a High level. The first device has highest 
priority, while each succeeding device has a 
corresponding lower priority. This arrange- 
ment permits the CPU to select the highest 
priority interrupt from several simultaneously 
interrupting peripherals. 

The interrupting device disables its IEO line 
to the next lower priority peripheral until it has 
been serviced. After servicing, its IEO line is 
raised, allowing lower priority peripherals to 
demand interrupt servicing. 

The Z80 CPU will nest (queue) any pending 
interrupts or interrupts received while a 
selected peripheral is being serviced. 

Interrupt Enable/Disable Operation. Two 

flip-flops, IFFj and IFF2, referred to in the 
register description are used to signal the CPU 
interrupt status. Operation of the two flip-flops 
is described in Table 2. For more details, refer 
to the Z80 CPU Technical Manual and Z80 
Assembly Language Manual. 



Action 



IFFi IFF2 



Comments 



CPU Reset 

DI instruction 
execution 

EI instruction 
execution 

LD A, I instruction 
execution 

LD A,R instruction 
execution 

Accept NMI 



RETN instruction 
execution 







IFF) 



IFF 2 



Mask able interrupt 
INT disabled 

Mask able interrupt 
INT disabled 

Mask able interrupt 
INT enabled 

IFF 2 - Parity flag 



IFF 2 - Parity flag 

IFFj - IFF 2 
(Mas kabl e inter- 
rupt INT disabled) 

IFF 2 - IFFj at 
comp letion of an 
NMI service 
routine. 



e 
o 

a 



Table 2. Stat* o! Flip-Flops 



Instruction The Z80 microprocessor has one of the most 

Set powerful and versatile instruction sets 

available in any 8- bit microprocessor. It 
includes such unique operations as a block 
move for fast, efficient data transfers within 
memory or between memory and I/O. It also 
allows operations on any bit in any location in 
memory. 

The following is a summary of the Z80 
instruction set and shows the assembly 
language mnemonic, the operation, the flag 
status, and gives comments on each instruc- 
tion. The Z80 CPU Technical Manual 
(03-0029-01) and Assembly Language 
Programming Manual (03-0002-01 ) contain 
significantly more details for programming 
use. 

The instructions are divided into the 
following categories: 

D 8-bit loads 

□ 16-bit loads 

D Exchanges, block transfers, and searches 

□ 8-bit arithmetic and logic operations 

□ General-purpose arithmetic and CPU 
control 



D 16- bit arithmetic operations 

□ Rotates and shifts 

D Bit set, reset, and test operations 

□ Jumps 

D Calls, returns, and restarts 

D Input and output operations 

A variety of addressing modes are 
implemented to permit efficient and fast data 
transfer between various registers, memory 
locations, and input/output devices. These 
addressing modes include: 

D Immediate 

□ Immediate extended 
D Modified page zero 

□ Relative 
D Extended 

□ Indexed 

□ Register 

□ Register indirect 

□ Implied 
D Bit 



8-Bit 
Load 
Group 



Symbolic 
Operation 



LDr. r' r - r' 

LD r. n r - n 



LD r, (HL) r - (HL) 

LDr, (lX + d) r-(IX + d) 



LDr. (IY + d) r-(IY + d) 



LD (HL). r (HL) - r 

LD(IX + d), r <IX + d)- 



LDUY + d). r (IY + d) - r 

LD (HL), n (HL) - n 

LD(IX + d), n (IX + d) - n 

LD(IY + d), n (IY+d) - n 



LD A. (BC) A - (BC) 

LD A. (DE) A - (DE) 

LD A. (nn) A - (nn) 



LD (BC), A (BC) - A 
LD (DE), A (DE) - A 

LD (nn). A (nn) - A 



LDA, I 


A - I 


LD A, R 


A - R 


LDI, A 


I - A 


LDB, A 


R - A 









Flags 






Opcode 




Ho.ol 


Ko.ol M No.oi T 






S 


z 




H 




P/V 


N C 


78 $49 210 


Hon 


BftM 


Cycle* 


State. 


( 


Seam* 


. 


. 


X 


. 


X 


. 


• • 


01 r r' 




1 


1 


4 


r, r' 


Reg. 


* 


• 


X 


• 


X 


• 


• * 


00 r no 
— n — 




2 


2 


7 


000 
001 


B 
C 


• 


• 


X 


• 


X 


• 


• • 


01 r no 




1 


2 


7 


010 


D 






X 




X 






11 011 101 

01 r 101 

-d - 


DD 


3 


S 


19 


on 

100 
101 


E 
H 
L 






X 




X 






11 111 101 

01 r 110 

-d- 


FD 


3 


5 


19 


111 


A 


• 


• 


X 


• 


X 


• 


• • 


01 110 r 




1 


2 


7 










X 




X 






11 011 101 

01 110 r 

- d - 


DD 


3 


5 


19 










X 




X 






11 111 101 

01 110 r 

- d - 


FD 


3 


5 


19 






• 


• 


X 


* 


X 


• 


* * 


oo no no 


36 


2 


3 


10 






* 


• 


X 


• 


X 


• 


• • 


n on 101 

oo no no 

-d - 


DD 
36 


4 


5 


19 










X 




X 


* 


* * 


11 111 101 

oo no no 

-d- 
— n — 


FD 
36 


4 


5 


19 






• 


• 


X 


• 


X 


• 


• • 


00 001 010 


0A 


1 


2 


7 






• 


• 


X 


• 


X 


• 


• • 


oo on oio 


1A 


1 


2 


7 










X 




X 






00 111 010 
— n — 


3A 


3 


4 


13 






• 


• 


X 


* 


X 


• 


• • 


00 000 010 


02 


1 


2 


7 






• 


• 


X 


• 


X 


• 


• • 


00 010 010 


12 


1 


2 


7 










X 




X 






oo no oio 

— n — 


32 


3 


4 


13 






t 


1 


X 





X 


IFF 


• 


11 101 101 
01 010 111 


ED 

57 


2 


2 


9 






l 


1 


X 





X 


IFF 


• 


11 101 101 
01 011 111 


ED 
5F 


2 


2 


9 






• 


• 


X 


* 


X 


* 


• • 


11 101 101 
01 000 111 


ED 
47 


2 


2 


9 






• 


• 


X 


• 


X 


* 


* • 


11 101 101 
01 001 111 


ED 
4F 


2 


2 


9 







NOTES: r. r means any ol the registers A. B. C. D. E, H, L. 

IFF the content ol the interrupt enable llip-llop, (IFF) I 

copied into the P'V flag. 
For an explanation ol flag notation and symbols lor 
: tables, see Symbolic Notation section 
I tables. 
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16-Bit Load 
Group 



Symbolic 

Operation 



Flag* 

H P/V N 



Opcode Mo.ai Ho.e< M Ne.«i T 

71 543 110 Hex Byte* Cycle* Start** 



LD dd, nn dd — nn 

LD IX. nn DC - nn 

LD IY, nn IY - nn 



LDHL, (nn) H-(nn + l) 
L - (nn) 



LD dd, (nn) ddf{ - (nn+ 1) 
ddL - (nn) 



LDIX. (nn) IXH-(nn+l) 
IXl - (nn) 



IYh- (nn+1) 
1Y L - (nn) 



LD(nn), HL (nn + l)-H 
(nn)- L 



LD(nn). dd <nn+l)-ddH 
(nn) — dd[. 



LD (nn). IX 



LD (nn). IY 



LD SP. HL 
LD SP, IX 



PUSH IY 



POPqq 



POP IX 



POPIY 



(nn+1) - IX H 
(nn) - LXl 



(nn+1)- IY H 
(nn) - IY L 



SP- HL 

SP- IX 

SP - IY 

(SP-2) - qq L 
(SP-l)-qq H 
SP - SP -2 
(SP-2) - IX L 
(SP-D- IX H 
SP - SP -2 
(SP-2) - IY L 
(SP-D- IY H 
SP - SP -2 
q<JH-<SP+l) 
qqL - (SP) 
SP - SP +2 
IX H - (SP+1) 
K L - (SP) 
SP - SP +2 
IY H -(SP+1) 
IY L - (SP) 
SP - SP +2 



X • 

X • 

X • 

X • 



X • 

X • 

X • 

X • 

X • 

X • 

X • 



— n — 

11 Oil 101 DD 

00 100 001 21 

— n — 

11 HI 101 FD 

00 100 001 21 



11 101 101 ED 
01 ddl 011 

— n — 

— n — 

11 011 101 DD 
00 101 010 2A 

— n — 

— n — 

11 111 101 FD 
00 101 010 2A 



— n — 

11 101 101 ED 
01 ddO 011 

— n — 

— n — 

11 011 101 DD 
00 100 010 22 

— n — 

— n — 

11 111 101 FD 
00 100 010 22 

— n — 

— n — 

11 111 001 F9 
11 Oil 101 DD 
11 111 001 F9 
11 111 101 FD 
11 HI 001 F9 
11 qqO 101 



11 Oil 101 DD 
11 100 101 E5 



11 111 101 FD 
11 100 101 E5 



dd Pair 

00 BC 

01 DE 

10 HL 

11 SP 



11 qqO 001 



11 Oil 101 DD 
11 100 001 El 



11 HI 101 FD 
11 100 001 El 







<n 


Pair 


3 


11 


00 


BC 






01 


DE 






10 


HL 


4 


15 


11 


AF 


4 


IS 






3 


10 







NOTES: dd is any of the register pairs BC. DE, HL. SP. 
qq is any ol the register pairs AF. BC. DE. HL. 

(PAIR)^, (PAIR)l refer to high order and low order eight bits of the register pair respectively, 
e.g.. BCl - C. AF H = A. 



i 



Exchange, 
Block 
Transfer. 
Block Search 
Groups 



EX DE, HL 
EX AF. AF' 
EXX 



EX (SP), HL 



EX (SP), IY 



DE - HL 
AF - AF 
BC - BC' 
DE - DE' 
HL - HL' 
H -(SP+1) 
L - (SP) 
IXh-(SP+D 
DC L - (SP) 
IY H -(SP+1) 
IY L - (SP) 

(DE) - (HL) 
DE-DE + 1 
HL - HL+1 
BC - BC-1 

(DE) - (HL) 
DE - DE+1 
HL - HL + 1 
BC -BC-1 
Repeat until 
BC = 



X e X • • 

X • X • • 

X • X • • 

© 

X X I 



X X 



11 101 011 EB 1 
00 001 000 08 1 
11 011 001 D9 1 



11 100 011 E3 

11 011 101 DD 

11 100 011 E3 

11 111 101 FD 

11 100 011 E3 

11 101 101 ED 

10 100 000 A0 



11 101 101 ED 
10 110 000 B0 



I 


4 


Register bank and 
auxiliary register 
bank exchange 


5 


19 




6 


23 




6 


23 




4 


16 


Load (HL) into 
(DE), increment 
the pointers and 
decrement the byte 
counter (BC) 


5 


21 


HBC * 


4 


16 


HBC =0 



NOTE: ©P/V flag is il the result of BC - 1 =0. otherwise P/V « 1 . 



11 



Exchange, 

Block 

Transfer, 

Block Search 

Groups 

(Continued) 



Symbolic 
Operation 



Flags 

H P/V N C 



Opcode No.of No.ol M No.oJ T 

78 543 210 Hex Byte* Cycles SlalM 



(DE) - (HL) 
DE - DE - 1 
HL - HL - 1 
BC - BC-1 

(DE) - (HL) 
DE - DE - 1 
HL - HL - 1 
BC - BC-I 
Repeat until 
BC = 

A - (HL) 
HL - HL+1 
BC - BC-1 

A - (HL) 

HL - HL+1 
BC - BC-1 
Repeat until 
A = (HL) or 
BC = 

A - (HL) 
HL - HL-1 
BC - BC-1 

A - (HL) 

HL - HL-1 
BC - BC-1 
Repeat until 
A = (HL)or 
BC = 



© 

I 



X X 



t I X I X 
I t X I X 



I I X t X 



t I X t X 



© 

1 1 

© 

I 1 



11 101 101 ED 
10 101 000 A8 



II 101 101 ED 
10 111 000 B8 



11 101 101 


ED 


2 


10 100 001 


Al 




11 101 101 


ED 


2 


10 110 001 


Bl 


2 



© 






1 1 


* 


11 101 101 ED 
10 101 001 A9 


© 






1 1 




11 101 101 ED 
10 111 001 B9 



If BC * 
If BC = 



21 If BC * and 

A * (HL) 

16 II BC = or 

A = (HL) 



21 If BC * and 

A * (HL) 

16 If BC = or 

A = (HL) 



NOTES: Q P/V flag is if the result of BC- 1 « 0. otherwise P/V = 
(2) Z flag is I il A = (HL). otherwise Z » 0. 



8-Bit ADD A, r A - A + r 

Arithmetic add a, n a - a + „ 
and Logical 

Group ADD A. (HL) A - A + (HL) 

ADDA. (IX + d) A - A + (IX + d) 

ADDA, (lY+d) A - A + (IY + d) 



ADC A. s 




A - A + s + CY 


SUBs 




A - As 


SBC A. s 




A - A-s-CY 


ANDs 




A - A A s 


ORs 




A - A v , 


XORs 




A — A • s 


CPs 




A-s 


INCr 




r - r + 1 


INC (HL) 




(HL) -(HU+1 


INC (IX + 


d) 


(IX + d) - 
(IX + d)+l 


INC(IY + 


d) 


(IY + d)- 
(IY + d)+l 



I X V I 
I X V I 



I X V 1 



X I X 

X I X 

X I X 

X 1 X 

X X 

X X 

X I X 

X t X 

X I X 

X I X 



io [pool no 

11 011 101 

io 15551 1 io 

— d - 

11 ill 101 



10 i 



110 



- d - 

BSD 

§ng 

loTil 



OTol 


noi 


nm 


00 r Eg) 


oo notion 


n on ioi 


oo noirasi 


-ti- 


ll 111 101 


oo no IToTSl 



[Toil 



Reg. 



000 


B 


001 


C 


010 


D 


an 


E 


100 


H 


101 


L 


in 


A 



s is any of r, n, 
(HL), (IX + d). 
(IY + d) as shown 
for ADD instruction. 
The indicated bits 
replace the 10001 in 
the ADD set above. 



i is any of r, (HL), 
(IX + d). (IY + d) 
as shown for INC. 
DEC same format 
and state s as I NC 
Replace 1 1001 with 
HUH in opcode. 
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General- 
Purpose 
Arithmetic 
and 

CPU Control 
Groups 



Symbolic 
Opsjrattoa 



Flags 

H P/V N C 



Opced* No.ai H0.0I M No.oi T 

M 543 210 Hex Byta. Cycles State* 



NEG 

CCF 

SCF 

NOP 

HALT 

DI* 

EI • 

IMO 

IM 1 

IM2 



Converts ace. content 
into packed BCD 
following add or 
subtract with packed 
BCD operands. 

A -A 



CY - CY 

CY - 1 
No operation 
CPU halted 
IFF-0 
IFF - 1 
Set interrupt 

mode 
Set interrupt 

mode 1 
Set interrupt 

mode 2 



00 100 111 27 



00 101 111 2F 



11 101 101 ED 
01 000 100 44 
00 111 111 3F 

00 110 111 37 

00 000 000 00 

01 110 110 76 
11 110 011 F3 
11 111 011 FB 
11 101 101 ED 
01 000 110 46 
11 101 101 ED 
01 010 110 56 
11 101 101 ED 
01 011 110 5E 



Decimal adjust 
accumulator. 



Complement 

accumulator (one's 

comptement). 
Negate ace. (two's 

complement). 
Complement carry 

(lag. 
Set carry flag. 



NOTES: IFF indicates the interrupt enable flip-flop 
CY indicates the carry flip-flop. 
* indicates interrupts are not sampled at the end of El < 



e 
a 



16-Bit 

Arithmetic 

Group 



ADD HL, ss 
ADC HL. ss 



HL - HL + ss 

HL - HL + ss + CY 



SBCHL. ss HL-HL-ss-CY I I X 

ADD IX. pp IX - IX + pp • • X 



INCss 
INC IX 



DECss 
DEC IX 



ss - ss + 1 
IX - IX + 1 



ss — ss - 1 

IX - IX - 1 



11 101 101 ED 
01 ssl 010 

11 101 101 ED 
01 ssO 010 
11 011 101 DD 
01 ppl 001 



11 111 101 FD 
00 rrl 001 



00 ssO 01 1 

11 011 101 DD 

00 100 011 23 

11 111 101 FD 

00 100 011 23 
00 ssl 011 

II 011 101 DD 

00 101 011 2B 

11 111 101 FD 

00 101 011 2B 



Reg. 



00 


BC 


01 


DE 


10 


HL 


11 


SP 


pp 


JH 


00 


bC 


01 


DE 


10 


IX 


11 


SP 


IT 


Reg. 


00 


BC 


01 


DE 


10 


IY 


11 


SP 



NOTES: ss is any of the register pairs BC. DE. HL. SP. 
pp is any ol the register pairs BC. DE, IX. SP. 
rr is any of the register pairs BC. DE. IY. SP. 



Rotate and 
Shift Group 



RLCA 
RLA 
RRCA 
FRA 



f?3-MZLr=L J--' • • x o x • o i oooooiii 07 i 

A 

Lfcv] — ^T?"- — o~)-l • • X X • I 00 010 1 1 1 17 1 

A 

L | 7 -o ( J-fcvl • • X X • I 00 001 111 OF 1 

L- j 7 — .q I .|"cyTJ • • X X • I 00011 111 IF 1 



RLCr 


RLC (HL) 


RLC(IX + d) 


RLC(lY + d) 



■ L?l] — | 7 ' ]— 1 

(HL).(IX + d).(IY + d) 



I I X X P I 11 0O1 011 CB 
00 000 r 

I I X X P I 11 001 Oil CB 
00 000 110 

I I X X P t 11 011 101 DD 

11 001 Oil CB 



t t x o x p o i 



I I X X P I 



LfcV] T7T=Tr7L j 

m-r.(HL).(IX + d).(IY + d) 

L | 7 — .oi ZLrcT| , , x o x p o i 

m»r,(HL).(IX + d),(lY + d) 



00 000 110 

11 111 101 FD 
11 001 01! CB 
- d - 

oo ooo no 

010 



Rotate left circular 
accumulator. 



Rotate left 
accumulator. 



Rotate right circular 
accumulator. 



Rotate right 

ulator 



Rotate left ci 

register r. 

r Reg . 

000 B 

001 C 
010 D 

oi ; e 

100 H 

101 L 
III A 



Instruction format 
and states are as 
shown for RLC's. 
To form new 
opcode replace 
000 or RLC's 
with shown code. 
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Rotate and 
Shift Group 

(Continued) 



Symbolic 
Operation 



Flag* Opcod* No.oi No.ol M No.oi T 

H P/V N C 76 543 210 Hox BytM CycU» SlatM 



SLA i 

SRA i 
SRLn 
RLD 

RRD 



H 7 — ° I — -QEH I I X X P I 

m-r.(HL),(IX + d).(IY + d) 



LelI- — \ '• "H o | I X X P I 

m«r.(HL),(IX + d),(IY + d) 



J — ° I S t . X X P I 

■.(HL).(IX + d).(IY + d> 



■ H 1 — I -[CY] , | X X P t 

m-r.(HL).(IX-i-d),(IY + d) 

| J- - < [ 3 -~S1 



r -«|»-»l | I X X P 



EED 




nooi 




poll 




ED 




11 101 101 


ED 


01 101 111 


6F 


11 101 101 


ED 


01 100 111 


67 



18 Rotate digit let! and 

right between 
the accumulator 
and location (HL). 

18 The content ol the 

upper half ol 
the accumulator is 
unallected 



Bit Set, Reset bit b. r z - ^ 
and Test BIT b (HL) z _ { ^i )b 
Group 

BITb, (IX + d) b Z - (IX + d)b 



BITb. (IY + d) b Z- (IY + d) b 



X 


1 X 


X 





• 


ii ooi on cb 

01 b r 


X 


1 X 


X 





• 


11 001 011 CB 
01 b 110 


x : 


1 X 


X 







11 011 101 DD 
11 001 011 CB 

- d - 

oi b no 


X I 


[ X 


X 





• 


11 111 101 FD 
11 001 011 CB 
- d - 
01 b 110 



r Reg. 
000 B 



001 
010 



111 

b 



010 

on 



no 
in 



SET b. r r b - 1 

SET b. (HL) (HL) b - 1 

SETb. (IX + d) (IX + d) b - 1 

SETb. (IY + d) (IY + d) b - 1 



RES b, m m b - 

m - r, (HL). 
(IX + d), 
(IY + d) 



X 


• X 


• 


" • 


11 001 


on cb 


X 


• X 


• 


• • 


11 001 

El b 


Oil CB 

no 


X 


• X 






n on 

11 001 
- d 

ED b 


101 DD 
Oil CB 

no 


X 


• X 






n in 

11 001 

- d 

Efl b 


101 FD 

on cb 
no 


X 


• X 


• ' 


' • 


m 





To form new 
opcode replace 
[TO ol SET b, s 
with @. Flags 
and time stales fo 
SET instruction. 



NOTES: The notation m b indicates bit b (0 to 7) or location m. 



Jump 


IPnn 


PC - nn 


Group 








IP cc. nn 


II condition 
true PC - r 

continue 




JRe 


PC - PC+< 




IRC. e 


H C = 0. 

continue 
If C = 1, 
PC - PC+. 




IR NC. e 


II C = 1 . 
continue 
II C = 0. 
PC - PC+. 




JPZ. e 


HZ = 
continue 
HZ = 1, 
PC - PC-M 




!R NZ, e 


II Z = 1 , 
continue 
II Z = 0. 
PC - PC+< 




IP(HL) 


PC - HL 




IP (IX) 


PC - IX 



X • X 
X • X 



X • X 
X • X 



11 000 011 C3 3 



X • X 
X • X 



oo on ooo is 



00 111 000 38 
- e-2 - 



00 1 10 000 30 
- e-2 - 



00 101 000 28 
- e-2 - 



00 100 000 20 
- e-2 - 



11 iOl 001 E9 



11 011 101 DD 
11 101 001 E9 



Condition 



000 NZ non-zero 

001 Z zero 

010 NC non- carry 

011 C carry 

100 PO parity odd 

101 PE parity even 

1 10 P sign positive 

111 M sign negative 

II condition not met. 
II condition is met. 
II condition not met. 
II condition is met. 
II condition not met. 
If condition is met. 
II condition not met. 
If condition is met. 



Jump Group 

(Continued) 






Flags 



n 541 110 In Byte* Oreta. State. 



IP(IY) 
DJNZ.e 



PC-IY 

B-B-l 
HB -0. 
oonHniM 
UB#0, 
PC-PC+e 



It HI 101 FD 

11 101 001 E9 

00 010 000 10 
_,_2 _ 



NOTES: • rapr — nt s the estension In Dm relative addressing nodi. 

• if a signed Iwo'i complement number in In* rang* < - 136. 129 > . 

• -2 In In* opcode provides an effective a dJi asi ol pc + e es PC ii incremented 

by 2 prior to lha addition ol a. 



Call and 
Return Group 



CALL mi 


(SP-I)-PCh 
(SP-2) - PC L 
PC - nn 


CALLcc, nn 


Ii condition 
oc is false 
continue, 
otherwise una at 
CALLnn 


BET 


PCl-(SP) * 
PC H -(SP+1) 


RETcc 


Ii condition 
cc is false 
continue, 
otherwise 




same at 
RET 


RETI 
RETN 1 


Return from 
interrupt 
Return from 
nonmailable 
interrupt 


RSTp 


(SP-1)-PC H 
(SP-2)-PC L 
PCh-0 
PC L -p 



11 001 101 CD 3 



— n — 

11 cclOO 

— n — 

— n — 



10 If cc is false. 
17 If ccU true. 



X • X 
X • X 



X • X 
X • X 



11 001 001 C9 1 

11 ccOOO 1 

1 



11 101 101 ED 

01 001 101 4D 

11 101 101 ED 

01 000 101 45 



It cc is falae. 


If cc it true. 


cc Condition 


000 NZ non-zero 


001 Z cero 


010 NC non-carry 


011 C carry 


100 PO parity odd 


101 PE parity even 


1 10 P sign positive 


1 1 1 M sign negative 


t P 
000 OOH 


001 OBH 


010 10H 


011 18H 


100 20H 


101 2BH 


110 30H 


111 38H 



NOTE: 'RETN loads IFF 2 - IFFi 



a 



Input and m a. m 

Output Group INr(C) 



OUT (n). A 
OUT (C), r 



A-(n) 

r-(C) 

if r = 110 only the 

flags will be affected 

(HL) - (C) 
B-B-l 
HL - HL + 1 
(HL) - (C) 
B-B-l 
HL - HL + 1 
Repeat until 
B = 

(HL) - (C) 
B-B-l 
HL - HL-1 
(HL) - (C) 
B -B-l 
HL -HL-I 
Repeat until 
B = 
(n) - A 

(C)-r 



(C) - (HL) 
B -B-l 
HL - HL + 1 
(C) - (HL) 
B-B-l 
HL - HL + 1 
Repeat until 
B = 

(C) - (HL) 
B -B-l 
HL - HL-1 



© 
I X X X X 1 



1 X X X X 1 



© 

I X X X X 1 



1 X X X X 1 



11 011 011 DB 
— n — 
11 101 101 ED 
01 r 000 



11 101 101 ED 
10 100 010 A2 



11 101 101 ED 



n to An - A7 
Ace. to Ag - A15 
C to Ao - A7 
B to As - A15 



C to Ao - A7 
BtoAo- A15 



C to Aq - A7 



© 



I X X X X 1 



X X X X 1 



10 no 010 


B2 


2 


(If B*0) 
4 

(HB=0) 


16 


B to Ag - A15 


11 101 101 ED 
10 10! 010 AA 


2 


4 


16 


C to Ao - A7 
BtoAe- Ais 


11 101 101 
10 111 010 


ED 
BA 


2 
2 


5 
(If B#0) 

4 
(IfB=0) 


21 

16 


C to Ao - A7 
Bio An- Ais 


11 010 011 
— n — 
11 101 101 
01 r OOl 


D3 
ED 


2 
2 


3 
3 


11 
12 


n to Aq - A7 
Ace. to As - Ajs 
C to Ao - A7 
B to As - A15 


11 101 101 
10 100 Oil 


ED 
A3 


2 


4 


16 


C to Ao - A7 
B to A 8 - A15 


11 101 101 

10 110 on 


ED 
B3 


2 
2 


5 
(II B*0) 

4 
(HB = 0) 


21 
16 


C to A© - A7 
BtoAs- A15 



© 



I X X X X 1 



11 101 101 ED 
10 101 011 AB 



C to Ao - A7 
B to As - A|s 



NOTE: Q) If (he result of B - 1 is zero the Z (lag i» Mi. otherwise il is reset. 



2001001 
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Input and 




Symbolic 








Flags 






Opcod* N0.0I 


No.of M No.of T 


Output Group 

(Continued) 


Mnemonic 


Operation 




s z 




H 




P/V 


N C 


76 543 210 Hm BytN 


CycUc State Comments 


OTDR 


(C) - (HL) 






X 1 


X 


X 


X 


X 


1 • 


11 101 101 ED 2 


5 21 C to Ao - A7 






B -B-1 


















10 111 on 


(If B*0) BtoAe - A15 






HL - HL-1 


















2 


4 16 






Repeat until 




















(If B = 0) 






B = 






















Summary of 






D7 














DO 






Flag 
Operation 


Instruction 




S 


z 




H 




P/V 


N 


c 


ComsMnte 




ADD A. 3; ADC A, s 




t 


X 


1 


X 


V 





1 


8-bit add or add with carry. 




SUB s; SBC A. 


s; CP s; NEG 




t 


X 


1 


X 


V 


1 


I 


8-bit subtract, subtract with 


carry, compare and negate accumulator. 




AND « 






t 


X 


1 


X 


p 





SI 








OH s, XOR s 






1 


X 





X 


p 





Logical operations. 






INCs 






t 


X 


1 


X 


V 





• 


8-bit increment. 






DECs 






t 


X 


1 


X 


V 


1 


• 


8- bit decrement. 






ADD DD, s> 






• 


X 


X 


X 


• 





1 


16-bit add. 






ADC HL. ss 






I 


X 


X 


X 


V 





I 


16-bit add with carry. 






SBC HL, ss 






t 


X 


X 


X 


V 


1 


1 


16-bit subtract with carry. 






RLA, RLCA, RRA; RRCA 




• 


X 





X 


• 





I 


Rotate accumulator. 






RL m: RLC m; 


RRm; 




t 


X 





X 


p 





1 


Rotate and shift locations. 






RRC m; SLA 


m; 
























SRA m; SRL 


























RLD; RRD 






1 


X 





X 


p 





• 


Rotate digit left and right. 






DAA 






1 


X 


I 


X 


p 


• 


t 


Decimal adjust accumulator. 






CPL 






• 


X 


1 


X 


• 


1 


• 


Complement accumulator. 






SCF 






• 


X 





X 


• 





1 


Set carry. 






CCF 






• 


X 


X 


X 


• 





t 


Complement carry. 






IN r (C) 






1 


X 





X 


p 





• 


Input register indirect. 






INI, IND, OUTI 


OUTD 


X 


t 


X 


X 


X 


X 


1 


:) 


Block input and output. Z = 


if B * otherwise Z = 0. 




INIR; INDR; OTIR; OTDR 


X 


1 


X 


X 


X 


X 


1 








LDI; LDD 




X 


X 


X 





X 


1 





:) 


Block transfer instructions. P/V = 1 il BC * 0, otherwise P/V = 0. 




LDIH; LDDR 




X 


X 


X 





X 














CPI; CPIR; CPD; CPDR 


X 


1 


X 


X 


X 


1 


1 


• 


Block search instructions. Z 


= 1 if A = (HL). otherwise Z = 0. P/V - 1 
























if BC * 0, otherwise P'V 


= 0. 




LD A, I, LD A, 


R 


1 


1 


X 





X 


IFF 





• 


The content of the interrupt « 


>nable flip-flop (IFF) is copied into the P/V flag. 




BIT b. s 




X 


t 


X 


1 


X 


X 





• 


The state of bit b of location 


s is copied into the Z flag. 



Symbolic Symbol Operation 

Notation ■* ^ ign ^ ag- S = 1 if the MSB of the result is 1. 

Z Zero flag. Z = 1 if the result of the operation is 0. 

P/V Parity or overflow flag. Parity (P) and overflow 

(V) share the same flag. Logical operations affect 
this flag with the parity of the result while 
arithmetic operations affect this flag with the 
overflow of the result. If P/V holds parity, P/V = 
1 if the result of the operation is even, P/V = if 
result is ,. id. If P/V holds overflow, P/V = 1 if 
the resu ! •-■ the operation produced an overflow. 

H Half-cai; iag. H = 1 if the add or subtract 

operatic ■ .oduced a carry into or borrow from 
bit 4 of : accumulator. 

N Add/Su! ' ict flag. N = 1 if the previous opera- 

tion was ubtract. 

H & N H and N .rjs are used in conjunction with the 

decimal ist instruction (DAA) to properly cor- 
rect the ,lt into packed BCD format following 
addition iubtraction using operands with 
packed 1 J format. 

C Carry/Li flag. C = 1 if the operation produced 

a carry f; <n the MSB of the operand or result. 



Symbol 

I 



Operation 

The flag is affected according to the result of the 

operation. 

The flag is unchanged by the operation. 

The flag is reset by the operation. 

The flag is set by the operation. 

The flag is a "don't care." 

P/V fljg affected according to the overflow result 

of the operation. 

P/V flag affected according to the parity result of 

the operation. 

Any one of the CPU registers A, B, C, D, E, H, L. 

Any 8-bit location for all the addressing modes 

allowed for the particular instruction. 

Any 16-bit location for ail the addressing modes 

allowed for that instruction. 

Any one of the two index registers IX or IY. 

Refresh counter. 

8-bit value in range < 0, 255 > . 

16-bit value in range < 0, 65535 > . 
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Pin A0-A15. Address Bus (output, active High, 

Descriptions 3-state). A0-A15 form a 16-bit address bus. The 
Address Bus provides the address for memory 
data bus exchanges (up to 64K bytes) and for 
I/O device exchanges. 



BUSACK. Bus Acknowledge (output, active 
Low). Bus Acknowledge indicates to the 
requesting device that the C PU add r ess bus , 
dat a bus, an d control signals MREQ, IORQ, 
RD, and WR have entered their high- 
impedance states. The external circuitry 
can now control these lines. 



BUSREQ. Bus Bequest (input, active L ow). 
Bus Request has a higher priority than NMI 
and is always recog nized at th e end of the cur- 
rent machine cycle. BUSREQ forces the CPU 
addres s bus, d ata bus, and control signals 
MREQ, IORQ, RD, and WR to go to a high- 
impedance state so that other devices can 
control these lines. BUSREQ is normally wire- 
ORed and requires an extern al pullup for 
these applications. Extended BUSREQ 
periods due to extensive DMA operations can 
prevent the CPU from properly refreshing 
dynamic RAMs. 

D0-D7. Data Bus (input/output, active High, 
3-state). D0-D7 constitute an 8-bit bidirectional 
data bus, used for data exchanges with 
memory and I/O. 



HALT. Halt State (output, active Low). HALT 
indicates that the CPU has executed a Halt 
instruction and is awaiting either a non- 
maskable or a maskable interrupt (with the 
mask enabled) before operation can resume. 
While halted, the CPU executes NOPs to 
maintain memory refresh. 

INT. Interrupt Request (input, active Low). 
Interrupt Request is generated by I/O devices. 
The CPU honors a request at the end of the 
current instruction if the internal software- 
controlle d int errupt enable flip-flop (IFF) is 
enabled. INT is normally wire-ORed and 
requires an external pullup for these 
applications. 



IORQ. Input/ Outpu t Bequest (output, active 
Low, 3-state). IORQ indicates that the lower 
half of the address bus holds a valid I/O 

addre ss for an I/O read or write operation. 

IORQ is also generated concurrently with Ml 
during an interrupt acknowledge cycle to indi- 
cate that an interrupt response vector can be 



placed on the data bus. 

Ml . Machine Cyc le One (output, active Low). 
Ml, together with MREQ, indicates that the 
current machine cycle is the opcode fetch 
cycl e of an instruction execution. Ml, together 
with IORQ, indicates an interrupt acknowledge 
cycle. 



MREQ. Mem ory Beq uest (output, active 
Low, 3-state). MREQ indicates that the address 
bus holds a valid address for a memory read or 
memory write operation. 

NMI. Non- Maskable Interrupt (input, active 
Low). NMI has a higher priority than INT. NMI 
is always recognized at the end of the current 
instruction, independent of the 
status of the interrupt enable flip-flop, and 
automatically forces the CPU to restart at 
location 0066H. 

RD. Memory Bead (output, active Low, 
3-state). RD indicates that the CPU wants to 
read data from memory or an I/O device. The 
addressed I/O device or memory should use 
this signal to gate data onto the CPU data bus. 



RESET. Beset (input, active Low). RESET 
initializes the CPU as follows: it resets the 
interrupt enable flip-flop, clears the PC and 
Registers I and R, and sets the interrupt status 
to Mode 0. During reset time, the address and 
data bus go to a high-impedance state, and all 
control o utput si gnals go to the inactive state. 
Note that RESET must be active for a minimum 
of three full clock cycles before the reset 
operation is complete. 



RFSH. Beires h (outp ut, active Low). RFSH, 
together with MREQ, indicates that the lower 
seven bits of the system's address bus can be 
used as a refresh address io the system's 
dynamic memories. 

WAIT. Wait (input, active Low). WAIT 
indicates to the CPU that the addressed mem- 
ory or I/O devices are not ready for a data 
transfer. The CPU continues to enter a Wait 
state a s long as this signal is active. Extended 
WAIT periods can prevent the CPU from 
refreshing dynamic memory properly. 

WR. Me mor y Write (output, active Low, 
3-state). WR indicates that the CPU data bus 
holds valid data to be stored at the addressed 
memory or I/O location. 
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CPU Timing The Z80 CPU executes instructions by pro- 

ceeding through a specific sequence of opera- 
tions: 

■ Memory read or write 

■ I/O device read or write 

■ Interrupt acknowledge 



The basic clock period is referred to as a 
T time or cycle, and three or more T cycles 
make up a machine cycle (Ml , M2 or M3 for 
instance). Machine cycles can be extended 
either by the CPU automatically inserting one 
or more Wait states or by the insertion of one 
or more Wait states by the user. 



Instruction Opcode Fetch. The CPU places 
the contents of the Program Counter (PC) on 
the address bus at the start of the cycle (Figure 
5). Ap proximately one- half clock cycle later, 
MREQ goes active. The falling edge of MREQ 
can be used directly as a Chip Enable to dyna- 
mic memories. When active, RD indicates that 
the memory data can be enabled onto the CPU 



data bus. 

The CPU samples the WAIT input with the 
rising edge of clock state T3. During clock 
states T3 and T4 of an Ml cycle dynamic RAM 
refresh can occur while the CPU starts 
decoding and executing the instruction. When 
the Refresh Control signal becomes active, 
refreshing of dynamic memory can take place. 




NOTE: T w -Wait cycle added when necessary lor slow ancilliary devices. 

Figure 5. Instruction Opcode Fetch 



CPU Memory Read or Write Cycles. Figure 6 

Timing shows the timing of memory read or write 

(Continued) cycl es othe r than an opcode fetch (Ml) cycle. 
The MREQ and RD signals function exactly as 
in the fetch cycle. In a memory write cycle, 
MREQ also becomes active when the address 



bus is stable, so that it can be used directl y as 
a Chip Enable for dynamic memories. The WR 
line is active when the data bus is stable, so 
that it can be used directly as an R/W pulse to 
most semiconductor memories. 



WRITE 
OPERATION 



Oo-Ot 




i 



Figure 6. Memory Read or Write Cycles 
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CPU Input or Output Cycles. Figure 7 shows the 

Timing timing for an I/O read or I/O write operation. 

(Continued) During I/O operations, the CPU automatically 



inserts a single Wait state (T w ). This extra Wait 
state allows sufficient time for an I/O port to 
decode the address and the port address lines. 




NOTE: T w « = One Wait cycle automatically inserted by CPU. 

Figure 7. Input or Output Cycles 



Interrupt Request/ Acknowledge Cycle. The 

CPU samples the interrupt signal with the ris- 
ing edge of the last clock cycle at the end of 
any instruction (Figure 8). When an interrupt 
is accepted, a special Ml cycle is generated. 



During thi s Ml cyc le, IORO becomes active 
(instead of MREQ) to indicate that the inter- 
rupting device can place an 8-bit vector on the 
data bus. The CPU automatically adds two 
Wait states to this cycle. 
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NOTE: 1)Tl= Last state of previous instruction. 2) Two Wait cycles automatically inserted by CPU(*). 

Figure 8. Interrupt Request/ Acknowledge Cycle 
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CPU Non- Maskable Interrupt Request Cycle. 

T imin g NMI is sampled at the sa me t ime as the 

(Continued) maskable interrupt input INT but has higher 

priority and cannot be disabled under software 
control. The subsequent timing is similar to 



that of a normal memory read operation except 
that data put on the bus by the memory is 
ignored. The CPU instead execut es a r estart 
(RST) operation and jumps to the NMI service 
routine located at address 0066H (Figure 9). 



J^J^J\f\I\f\J\f' 
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'Although NMI is an asynchronous input, to guara ntee its being 
recognized on the following machine cycle, NMI's falling edge preceding Tij^sT 



must occur no later tt the rising edge of the clock cycle 
preceding TlasT- 

Figure 9. Non-Maskable Interrupt Request Op ion 



Bus Req uest/ Ack nowledge Cycle. The CPU 

samples'BUSREQ with the rising edge of the 
last cl ock period of any machine cycle (Figure 

10). If BUSREQ is active, t he CP U sets its 

address, data, and MREQ, IORQ, RD, and WR 



lines to a high impedance state with the rising 
edge of the ne ■ :lock pulse. At that time, any 
external devic» >an take control of these lines, 
usually to transier data between memory and 
I/O devices. 



NOTE: Tl= Last state of any M cycle 




Tx = An arbitrary clock cycle used by requesting device. 



Figure 10. Bus Request/Acknowledge Cycle 



2005 0218, 886 
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CPU Halt Ackn owled ge Cycle. When the CPU 

Timing receives a HALT inst ruct ion , it e xecutes NOP 

(Continued) states until either an INT or NMI input is 



received. When in the Halt state, the HALT 
output is active and remains so until an inter- 
rupt is processed (Figure 11). 



U-f® —I t*® 



X 



J 



w 



<2>* 



NOTE: INT will also force a Halt exit. 



'See note. Figure 9. 



Figure 11. Halt Acknowledge Cycle 



Reset Cycle. RESET must be active for at least inactive, two internal T cycles are consumed 

three clock cycles fo r the CP U to properly before the CPU re sumes normal processing 

accept it. As long as RESET remains active, the operation. RESET clears the PC register, so the 

address and data buses flo at, and the control first opcode fetch will be to location 0000 

outputs are inactive. Once RESET goes (Figure 12). 




Figure 12. Reset Cycle 
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AC 

Charac- 
teristics 



Numbsr Symbol 



Parameter 



Z80CPU 
Min Max 

(ns) (ns) 



Z80ACPO 
Min Max 

(at) (ns) 



1 TcC 

2 TwCh 

3 TwCl 

4 TfC 

5 — TrC 

6 TdCr(A) 

7 TdA(MREQf) 



Clock Cycle Time 400* 
Clock Pulse Width (High) 180* 
Clock Pulse Width (Low) 180 
Clock Fall Time — 
■ Clock Rise Time 



Clock I to Address Valid Delay 



TdCf(MREQf) 
TdCr(MREQr) 

TwMREQh 

TwMREQl 
TdCf(MREQr) 
TdCf(RDf) 
TdCr(RDr) 

15 TsD(Cr) 

16 ThD(RDr) 



Address Valid to MREQ 
1 Delay 

Clock 1 to MREQ I Delay 



Clock t to MREQ t Delay 



KffiEQ" Pulse Width (High) 



MREQ Pulse Width (Low) 



17 

18 

19 

20- 

21 

22 

23 

24 

25- 



TsWAIT(Cf) 

ThWAIT(Cf) 

TdCr(Mlf) 
■TdCr(Mlr) — 

TdCr(RFSHf) 

TdCr(RFSHr) 

TdCf(RDr) 

TdCr(RDf) 
•TsD(Cf) 



Clock I to MREQ t Delay 
Clock 1 to RD I Delay 
Clock t to RD I Delay 
Data Setup Time to Clock t - 
Data Hold Time to RD t 
WAIT Setup Time to Clock I 



WAIT Hold Time after Clock 1 

Clock 1 to Ml I Delay 

Clock 1 to Ml t Delay 



Clock t to RFSH I Delay 



Clock t to RFSH t Delay 

Clock I to RD t Delay 

Clock t to RD I Delay 

Data Setup to Clock I during 
M2, M3, M4 or M5 Cycles 



26 TdA(IORQf) 

27 TdCr(IORQf) 

28 TdCf(IORQr) 

29 TdD(WRf) 

30 — TdCf(WRf) — 

31 TwWR 
TdCf(WRr) 
TdD(WRf) 
TdCr(WRf) 
TdWRr(D) — 



Address Stable prior to IORQ I 



Clock t to IORQ 1 Delay 



Clock I to IORQ t Delay 
Data Stable prior to WR 1 
Clock 1 to WR 1 Delay — 
WR Pulse Width 
Clock 1 to WR t Delay 
Data Stable prior to WR 1 
Clock t to WR I Delay 
Data Stable from WR t — 



TdCf(HALT) 

TwNMI 

TsBUSREQ(Cr) 



Clock I to HALT t or 1 
NMl Pulse Width 



BUSREQ Setup Time to Clock t 



2000 

- 30 
30- 

— 145 
125* — 

— 100 

- 100 



■170* 
360* 



50 
70 



-60- 
320* 



190* 



360* 

20* 

120* 

80 
80 



100 
130 
100 




130 
130- 
180 
150 
110 
100 



90 
110 



-90 
100 
80 



300 



250* 
110* 

110 2000 
- 30 

30' 



- 110 
65* — 

- 85 

- 85 
■110* 

220* - 

- 85 

- 95 

- 85 
-35 



70 



50 






100 
100' 
130 
120 
85 
85 



180* - 

— 75 

- 85 
80* — 

80- 



220* — 

- 80 
-10* - 

- 65 
-60* 

- 300 
80 — 
50 - 



'For clock periods other than the minimums shown in the table, 
calculate parameters using the expressions in the table on the 
following page. 



Z80BCPU 
Min Max 

(ns) (ns) 



165* 
65* 
65 2000 

— 20 
20 

— 90 



35* 



70 
70 



-65* 

135* — 

- 70 

- 80 

- 70 
-30 



— 
60 - 

— 

— 80 
80 



- 110 

- 100 

- 70 

- 70 
■40 



110* — 

— 65 

— 70 
25* — 

70 



135* — 

— 70 
-55* — 

— 60 
-30* 



— 260 
70 — 
50 — 



g 
1 
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AC 

Charac- 
teristics 

(Continued) 



Number Symbol 



Parameter 



Z80CPU 
Min Max 

(ns) (ns) 



Z80ACPU 
Min Max 

(ns) (ns) 



39 


ThBUSREQ(Cr) 


40- 


-TdCr(BUSACKf)' 


41 


TdCf(BUSACKr) 


42 


TdCr(Dz) 


43 


TdCr(CTz) 


44 


TdCr(Az) 


45- 


-TdCTr(A) 



BUSREQ Hold Time after Clock t 







-Clock t to BUSACK i Delay 



Clock I to BUSACK I Delay 

Clock t to Data Float Delay 

Clock t t o Cont r ol Ou tputs Float 
Delay (MREQ, IORQ, RD, 
and WR) 

Clock t to Address Float Delay 



• A ddress Stable after MREQ t , 
IORQ t, RD t, andWR t 



160*- 



RESET to Clock t Setup Time 



RESET to Clock t Hold Time 
INT to Clock t Setup Time 
INT to Clock ! Hold Time 



46 TsRESET(Cr) 

47 ThRESET(Cr) 

48 TsINTf(Cr) 

49 ThlNTr(Cr) 

50 — TdMlf(IORQf) — Ml i to IORQ 1 Delay 

51 TdCf(IORQf) 

52 TdCf(IORQr) 

53 TdCf(D) 



Clock 1 to IORQ 1 Delay 
Clock t to IORQ 1 Delay 
Clock 1 to Data Valid Delay 



120 
110 
90 
110 

110 



90 — 



920* 



110 
100 
230 







100 

- 100 

— 90 



- 90 
•80* 



60 



'For clock periods other than the minimums shown in the table, 
calculate parameters using the following expressions. Calculated 
values above assumed TrC = TIC = 20 ns. 



Footnotes to AC Characteristics 



Z80BCPU 
Min Max 

(ns) (ns) 







•35*' 
60 



•90 
90 
80 
70 

80 



- - 
80 — 70 — 

- - 
■ 565* 365* 

- 85 — 70 

- 85 — 70 

- 150 - 130 



Number Symbol 



Z80 



Z80A 



Z80B 



1 


TcC 


TwCh + TwCl + TrC + TfC 


2 
7 — 


TwCh 
- TdA(MREQf) - 


Although static by design, 
TwCh of greater than 200 us 
is not guaranteed 




10 


TwMREQh 


TwCh + TfC - 30 


11 


TwMREQl 


TcC - 40 


26 


TdA(IORQf) 


TcC - 80 


29 
31- 


TdD(WRf) 
- TwWR 


TcC - 210 




33 


TdD(WRf) 


TwCl + TrC - 180 


35 


TdWRr(D) 


TwCl + TrC - 80 


45 


TdCTr(A) 


TwCl + TrC - 40 


50 


TdMlf(IORQi) 


2TcC + TwCh + TfC - 80 



TwCh + TwCl + TrC +TfC 

Although static by design, 
TwCh of greater than 200 /is 
is not guaranteed 

TwCh + TfC - 65 

TwCh + TfC - 20 

TcC - 30 

TcC - 70 

TcC - 170 

TcC - 30 



TwCl + TrC - 140 
TwCl + TrC - 70 
TwCl + TrC - 50 
2TcC + TwCh + TfC - 65 



TwCh + TwCl + TrC + TfC 

Although static by design, 
TwCh of greater than 200 /ts 
is not guaranteed 

TwCh + TfC - 50 

TwCh + TfC - 20 

TcC - 30 

TcC - 55 

TcC - 140 

■ TcC - 30 



TwCl + TrC - 140 
TwCl + TrC - 55 
TwCl + TrC - 50 
2TcC + TwCh + TfC - 50 



AC Test Conditions: Vqh = 2.0 V 

v IH = 2.0 v Vql = °- 8 v 

V IL = 0.8 V FLOAT = ±0.5 V 

VlHC = V C C -0.6 V 
VlLC = 0.45 V 



24 



APPENDIX F.... FLOPPY ERROR CODE 
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Table 6 STATUS REGISTER SUMMARY 





ALL TYPE 1 


READ 


READ 


READ 


WRITE 


WRITE 


BIT 


COMMANDS 


ADDRESS 


SECTOR 


TRACK 


SECTOR 


TRACK 


S7 


NOT READY 


NOT READY 


NOT READY 


NOT READY 


NOT READY 


NOT READY 


S6 


WRITE 
PROTECT 











WRITE 
PROTECT 


WRITE 
PROTECT 


SS 


HEAD LOADED 





RECORD TYPE 





WRITE FAULT 


WRITE FAULT 


S4 


SEEK ERROR 


RNF 


RNF 





RNF 





S3 


CRC ERROR 


CRC ERROR 


CRC ERROR 





CRC ERROR 





S2 


TRACK 


LOST DATA 


LOST DATA 


LOST DATA 


LOST DATA 


LOST DATA 


SI 


INDEX 


DRQ 


DRQ 


DRQ 


DRQ 


DRQ 


SO 


BUSY 


BUSY 


BUSY 


BUSY 


BUSY 


BUSY 



STATUS FOR TYPE I COMMANDS 



BIT NAME 


MEANING 


S7 NOT READY 


This bit when set indicates the drive is not ready. When reset it indicates that the drive 
is ready. This bit is an inverted copy of the Ready input and logically 'ored' with MR. 


S6 PROTECTED 


When set, indicates Write Protect is activated. This bit is an inverted copy of WRPT 
input. 


S5 HEAD LOADED 


When set, it indicates the head is loaded and engaged. This bit is a logical "and" of 
HLD and HLT signals. 


S4 SEEK ERROR 


When set, the desired track was not verified. This bit is reset to when updated. 


S3 CRC ERROR 


CRC encountered in ID field. 


S2 TRACK 00 


When set, indicates Read/Write head is positioned to Track 0. This bit is an inverted 
copy of the TROO input. 


SI INDEX 


When set, indicates index mark detected from drive. This bit is an inverted copy of the 
IP input. 


SO BUSY 


When set command is in progress. When reset no command is in progress. 



STATUS FOR TYPE II AND III COMMANDS 



BIT NAME 


MEANING 


S7 NOT READY 


This bit when set indicates the drive is not ready. When reset, it indicates that the drive 
is ready. This bit is an inverted copy of the Ready input and 'ored' with MR. The Type II 
and III Commands will not execute unless the drive is teady. 


S6 WRITE PROTECT 


On Read Record: Not Used. On Read Track: Not Used. On any Write: It indicates a 
Write Protect. This bit is reset when updated. 


S5 RECORD TYPE/ 
WRITE FAULT 


On Read Record: It indicates the record-type code from data field address mark. 
1 = Deleted Data Mark. = Data Mark. On any Write: It indicates a Write Fault. This bit 
is reset when updated. 


S4 RECORD NOT 
FOUND (RNF) 


When set, it indicates that the desired track, sector, or side were not found. This bit is 
reset when updated. 


S3 CRC ERROR 


If S4 is set, an error is found in one or more ID fields; otherwise it indicates error in 
data field. This bit is reset when updated. 


S2 LOST DATA 


When set, it indicates the computer did not respond to DRQ in one byte time. This bit is 
reset to zero when updated. 


SI DATA REQUEST 


This bit is a copy of the DRQ output. When set. it indicates the DR is full on a Read 
Operation or the DR is empty on a Write operation. This bit is reset to zero when up- 
dated. 


SO BUSY 


When set, command is under execution. When reset, no command is under execution. 
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TECHNICAL APPLICATION NOTES FOR THE SUPER QUAD SINGLE BOARD COMPUTER. 

In case of problems with the SUPER QUAD; these are two thing a customer 
may do: 

1. send the product back for warranty service (turn around time is 1 day) 

2. follow thw following notes and then if there are still no results do 
the first stepl 

1. If the board is totaly dead and won't communicate with the CRT, then 
do the following: 

a. check you power supply for 5, + ,-12 volts. 

b. check pins 1,3,17 of the U53(BR1941) baud rate gen. for step type 
pulses. (if you do not see any thing on these pins then replace the 
BR1941 chip) 



c. Check your PS NET/I the serial port adapter cable for possible 
loss of + or - 12 volts or the 1488 chip. 

d. check pin 3 of Ull(741sll). there should be a positive going 
signal (about 5 volts) and when you press RESET you should see that 
pulse going to ZERO voltage. 

e. If the step d is OK then you have a problem with either on of the 
a or b or c . 

f. check the 4MHZ clock signal going to pin 6 of the CPU. 

2. If there is a problem with the floppy disk controller part only and 
you think that the phase lock loop needs to be adjusted, then follow 
the folowing steps: 

a. This is done with the help of a dual trace scope. 

b. put one channel on the 4MHZ signal (PIN 6 of the cpu chip) 

put the other channel on pin 7 of the U27(74sl24) and by tweeking 
the R26(pot) those two signals are supposed to lock. 

c. the above procedure is only recomended to engineeres or technicians 
with experience of doing such things before. 

3. Make sure the board is being properly cooled by a fan. 

4. The power consumption of the board is: 
+ 8v 1.8 amps max. 

+ 16 .4 amps max. 

-16 .2 amps max. 

5. To ensure the proper operation of your floppy disk drives, make 
sure to put the termination resistor at the end of the cable. 

6. Retcr to the softare manual for software problems. 
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Application notes to run TURBO-DOS operating system: 

If you have one of the early revisions of the SUPERQUAD check the following 

1. pin 13 of the CTC should be hooked to +5V. 

2. R17 should be hooked to +5. 

3. for double sided drives, there should be a jumper from j3 connector 
to PIO bit3(PIO-29) 

4. 1E3 lin2 (PIO-22) should goto ul8-9, on some older tev. boards its 
also going to pin 12 of ul4. the place to cut would be on top of u8 
right above pin 20 there is a pad hole; the etch going north should be 
cut, then install a jumper from ul4-12 to ul5-6 
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application notes on how to interface the Measurement Systems Memory (DMB6400) 

to the SUPERQUAD. 

ON DMB6400 SET SWITCHES AS FOLLOWS : 
(TOGLE SWITCH... UP MEANS PRESS *£© TOE TOP DOWN) 
Sl-1 D0WN,Sl-2 DOWN.S1-3 DOWN, Sl-4 DOWN 

S2-l,2,4,5 UP S3-l,2 UP S4-l,4 DOWN S5-1 ,2,3 ,4 ,5 , 6,8 UP 

HEADER 1 SHOULD BE WIRED AS: PIN 1 TO 16,3 TO 9,7 TO 11,8 TO 10. 
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SUPER NET MODIFICATION SHEET 



To run the SUPER 0wao (Advanced Digital Corportio^s S-100 single 
board computer) with the BSR 64/256 (PCE Systems 1 256K RAM card) there 
are two modifications to be made to the SUPER. Qua*. The first 
modification (as described below) is to buffer the Z-80 refresh 
signal, and bring it to pin 66 of the S-100 bus (see figure 1). 



1) Solder a wire from U50, pin 28 
(Z-80} to U43, pin 14 (8T97). 2) 
Solder a wire from U43, pin 13 
(8T97) to pin 66 of the S-100 bus. 

The s e c ond "moo* if i ca t Fori - ne e*d s~ to ~be 
done so that the RAM card can sense 
when the Z80 is in a wait sta te. 
This is done by cutting the RAM 

RFSH and FDC WAIT signals on the 

SUPER fyyM> away from the inputs of HOLD 
U56, and ANDING them and tying the 
result to PRDY of the S-100 bus XRDY 
(see figure 2) . Because PRDY may be PRDY 
driven by a number of different 
cards, an open collector device is 
needed. For this purpose a 7409 is 

added to the board, as described __ ■, 

below, at SPARE location U57. (2-05)1 ^ RFSH r 

(4-C7) P DC WAIT 1 

Figure 2 

1) Solder a 14 pin socket in location U57 for a 7409. 2) Solder a 

wire from RM6, pin 2 to U57, pin 1. 3) Solder a wire from the plated 

through hole located under U55 between pins 13 & 14, to U57, pin X- 

4) Solder a wire from U57, pin 3 to U56, 




Pin 13 



RM6 



pin 4. 5) Cut two traces located on 
component side of board between U56 and 
RM6 (see figure 3). 6) Install a 7409 in CUTS 
U57. U56 



J 



V). 



C. V c 
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Parts list 



SUPER NET Parts list 



Item 


I Part Number ] 


Location on board 1 


[ Quantity 


1. 


I 74LS00 ] 


l U-13 ] 


I 1 


2. 


I 74S04 ] 


[ U-6 ] 


[ 1 


3. 


I 74LS04 ] 


[ U-18,U-34 ] 


[ 2 


4. 


I 7406 ] 


[ U-32 ] 


L 1 


5. 


I 7407 1 


l U-l ] 


[ 1 


6. 


I 74LS10 3 


L U-41 ] 


[ 1 


7. 


I 74LS11 ] 


: U-ll 1 


[ 1 


8. 


I 74LS13 ] 


[ U-47,U-56 ] 


L 2 


9. 


I 74LS14 , ] 


l U-2 ] 


[ 1 


10. 


I 74LS27 ] 


[ U-35 ] 


L 1 


11. 


I 74LS32 ] 


[ U-42,U-22 ] 


[ 2 


12. 


I 7438 ] 


[ U-14 ] 


L 1 


13. 


I 74LS74 ] 


U-33,U-40 1 


t 2 


14. 


I 74LS123 ] 


[ U-3,U-4 ] 


[ 2 


15. 


I 74S124 1 


: U-27 ] 


[ 1 


16. 


I 74LS132 1 


[ U-16,U-39,U-46 ] 


L 3 


17. 


I 74LS138 1 


: U-21,U-36 ] 


L 2 


18. 


I 74LS139 1 


[ U-5 ] 


[ 1 


19. 


I 74LS153 ] 


U-28 1 


: l 


20. 
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L U-10 ] 


[ l 


21. 
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L 2 
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[ 2 
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24. 
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[ 1 
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U-12 # U-7 ] 
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[ U-60 THRU U-67 ] 


[ 8 


31. 


I Z-80A CPU 1 


1 U-50 1 


[ 1 


32. 


I Z-80A PIO 1 


[ U-9 ] 


[ 1 


33. 


I Z-80A DARTISIO)! 


[ U-52 ] 


L 1 


34. 


I Z-80A CTC ] 


[ U-37 ] 


[ 1 
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I WD-1793(8877) 1 


1 U-26 ] 


[ 1 
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L U-19 1 


[ 1 
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I 1 
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L 1 
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[ 1 
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L U-43 ] 


L 1 


42. 


I 8T98 ] 


[ U-55,U-15 ] 


[ 2 


43. 


I 14 PIN HEADER ] 


L U-31 1 


[ 1 


44. 


I LM323K VOLT. ] 


[ VR1 ] 


[ 1 


45. 


I 8.000 MHZ XTAL 1 


L Yl 1 


[ 1 


46. 


I 5.06 MHZ XTAL ] 


[ Y2 ] 


[ 1 


47. 


I 16 PIN SWITCH ] 


L SW1 ] 


[ 1 


48. 


I 2N2222 TRANS. 1 


t Q1,Q2,Q4 ] 


[ 3 


49. 


I 2N3906 TRANS. 1 


L Q3 ] 


[ 1 



50. 
51. 
52. 
53. 
54. 
55. 
56. 
57. 
58. 
59. 
60. 
61. 
62. 
63. 
64. 
65. 
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78L12 1 


t Q5 




[ 1 


I 


220 MH CHOKE 1 


L Ll,1 


L2 ] 


[ 2 


I 
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I 3 


I 


10K SIP ] 


[ RM2 


,RM5 ] 


t 2 


I 


33 OHM SIP ] 


[ RM6 




[ 1 


I 
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[ RM4 




L 1 


I 


33 OHM DIP 1 


[ RM8 




[ 1 


I 


1N914 DIODE ] 


L CR2 




[ 1 


I 


5.1 V ZENER ] 


[ CR1 




[ 1 


I 
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[ C2 




[ 1 


I 


.1 MF CAP 1 






[ 21 


I 


4.7 MF CAP ] 


[ ' C6,( 
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[ 8 
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10K POT 1 


[ R27 


r R28 1 


[ 2 


I 


14 PIN HEADER 1 


[ \J4,J5 ] 


[ 2 


I 


50 PIN HEADER ] 


[ J3 




L 1 


I 


40 PIN HEADER 1 


[ J2 




[ 1 
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" ADVANCED 
DIGITAL 

CORPORATION, 



WARRANTY NOTICE 



Advanced Digital Corporation now requires a Return Authorization 
Number for the return of any equipment for repair or credit. This 
number will be issued by the Customer Support Department. Any 
equipment received without the Return Authorization Number clearly 
marked on the outside of the package may be subject to significant 
delays in the repair process. 

Return Authorization Numbers are active for 30 days after they are 
issued. If the equipment specified in the Return Authorization is 
not received by Advanced Digital within this 30 day period signi- 
ficant delays in handling the repair may be incurred. 

If the equipment must be returned a second time, a new Return 
Authorization Number must be issued. Reuse of Return Authorization 
Numbers may result in delays in processing returns. 

Effective November 1, 1981, repair of all kit and nonwarranty 
boards will be $70.00. This fee is subject to change without 
notice. 

Returns for credit will be subject to a 15% restocking charge. If 
material for credit was purchased through a dealer, Advanced Digital 
cannot issue a credit. Adjustment must be handled through the dealer. 
Other credit returns should have reference to the original invoice 
number. 

If you have any questions regarding special handling, packaging of 
the equipment, or procedures for returning equipment, please contact 
the Advanced Digital Corporation. 



The warranty on the super quad is one year from the date of purchase. 



